











1١ احجان حر‎ M7 
ع 2010 عادر لويد ون‎ 


من الصفر إلى الاحتراف: 
برمحة قواعد البيانات 
باستخدام تقنية 10.017 
في 
فيجيوال بيزيك دوت نت ۲۰۱٠۰‏ 


بقلم: 
م. محمد حمدي غانم 


هذا الكتاب صدقة جارية على روح والدي: 
أ. حمدي كامل الحديدي غانم 


رحمه الله وغفر له وجعل مثواه الجنة 


لهذا أرجو من كل من يستفيد به أن يتذكر أن أبي هو الذي رباني 
رف رر يغ اترفيق انما كرح إلى الريحوه هذا الا و غير 
من الكتب. 

انوا له بالرحمة والغفرة 


ومن كان منكم في الحرمين الشريفين وكان قادرا على عمل عمرة له. فجزاه الله خيرا. 


أدعو الله أن يكون هذا الكتاب وباقي كتبي من العلم الذي ينتفع به وأن يجعل الله لأبي 
نصيبا من ثوابه. فيكون من عمله الذي لا ينقطع بموته. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
آمين يا رب العالمين 


LL Ck |‏ 
| 3 0 7 1 پا للعجب1 ١‏ 
بے لاا مد غاب وجهك واحتجَب 
o aia u}‏ قب يبك راضية مرضنة صاز الترب كما الذهب 
فاحثلي في عباتي واتثلي جف ے ہے الان مسكك ناب فيه مُودَعًا ليل الثم 
إنالته وانا اليه رلجعون 


يا للعجب 1 
ناداك ربك ے رجب 
لبيّت شوقا پا أبي. 
ب جمعت الإسراء جاوزت الحجپ 
لكنه انی ذهب 
سيل وجهك چ خبالي مثلما قلبي حب 
يا للعجب!1 
هو عست مور وج 
ياتي الفراق مُسببًا لعقولنا وبلا سبب 
لكنتا نتسَى لقا ولا نرك إذا اقترب 
ے لمح تدمي مخالبْه القلوب. فيستشيط بها الثهب 


پا للعجت1 
قد فقت شعري الْنتجَثٍ 
نَفِدَتَ يُتَابِيعٌ الكلام وليس ترتيك الكَدّب 
إن #لحياة يلا وجودك يا حبيبي 
ذكرياتٌ حُلوةٌ كلها صارث لفقدك تثحب 
الاس ااذ قانمم اك بلا تقب 


ری كيز ار 0 
وس 2 ٤‏ ا 5 . ٠‏ 
ف Ae fola erf YII‏ 0 مہ مد سيا , 
په ام 





يا للعجب! 
مذ غاب وجك واحتجِب 
ا ارا ااا 
ألأنَ مسكك ذاب فيه مُوذَعًا ليل التعب؟ 


سيل وجا فى كبا عنتما ئی ا 


٤ 


يا للعجبا 
هو حسب مقدورٌ وجب 
يأتي الفراق سب با لعقولناء وبلا سيب 
لكننا ننس لقاة ولا تراه إذا اقترف! 
في لمحة تدمي مَخالبُ القلوب» فيستشيط بها اللهبا 


يا للعجب 
نفدت ابيع الكلام وليس ترثيك الكتب 
إن الحياة بلا وجودك يا حبيبي 
کات كاز كديا ات و 
فانعَمْ هناك بلا نصَبْ 


وإلى لقاء مر تقب 


محمد حمدي غانم 


۲۰1/7٦ 


توا الكاتب: 


- بريدي الالكتروني: 
msvbnet@hotmail.com‏ 
- مدو نتي 
http://mhmdhmdy.blogspot.com‏ 
- قناتي على يوتيوب (تحتوي على إلقاء أكثر من ٠٠‏ قصيدة بصوتي): 
http://www.youtube.conm/user/mhmdhmdy‏ 
- صفحتي الأدبية على فيسبوك: 
https://www.facebook.com/Poet.Mhmd.Hmdy‏ 
- كتبي في مجال البرمجة بلغتي فيجوال بيزيك وسي شارب: 
http://mhmdhmdy.blogspot.com/2010/09/blog-post 95555.html‏ 
- صفحة فيجوال بيزيك وسي شارب على فيسبوك: 
https:/www.facebook.com/vbandcsharp‏ 


كتب مجانبة للكاتب للتذزيل: 
١‏ - كتب برمجية على موقع كتب: 


محمد ١‏ "“حمدي, ٠‏ ۲ غخilم/http://www.kutub.info/Iibrary/autho1‏ 
۲ - كتاب: "خرافة داروين» حينما تتحول الصدفة إلى علم": 
http:/mhmdhmdy.blogspot.com/2013/11/blog-post 29.html‏ 
۳ - ديوان دلال الورد (شعر فصيح): 
http ://www.mediafire.com/?n1qte7]9hdv1198‏ 
٤‏ ديوان فنجان وجع (شعر عامية): 
http://www.mediafire.com/download/gzivkgedtvx2e4j/Pain_Cup.pdf‏ 
ه - رواية 'حائرة في الحب: 
http://www.mediafire.com/?hd1]y6ca4ay3m9w‏ 
5 - رواية "حب في القطار (عمو)": 
http://mhmdhmdy.blogspot.com.eg/2015/11/blog-post 39.html‏ 


كتب مطبوعة للكاتب: 

.١‏ فيجيوال بيزيك وسي شارب: طريقك المختصر للانتقال من إحدى اللغتين 
إلى الأخرى. 

؟. المبرمج الصغير: تعلم البرمجة بفيجيوال بيزيك دوت نت. 

۳. من الصفر إلى الاحتراف: فيجيوال بيزيك دوت نت .٠٠٠٠١‏ 

4. من الصفر إلى الاحتراف: سي شارب .۲٠٠١‏ 

5. من الصفر إلى الاحتراف: برمجة إطار العمل في فيجيوال بيزيك دوت نت. 

5. من الصفر إلى الاحتراف: برمجة إطار العمل في سي شارب. 

. من الصفر إلى الاحتراف: برمجة نماذج الويندوز في فيجيوال بيزيك دوت نت. 

. من الصفر إلى الاحتراف: برمجة نماذج الويندوز في سي شارب. 

. من الصفر إلى الاحتراف: برمجة قواعد البيانات في فيجيوال بيزيك دوت نت. 

٠‏ .من الصفر إلى الاحتراف: برمجة قواعد البيانات في فيجيوال سي شارب. 

١.المدخل‏ العملي السريع إلى فيجيوال بيزيك دوت نت. 

1.المدخل العملي السريع إلى سي شارب. 

١‏ .أساسيات 0۲۴ لمبرمجي فيجيوال بيزيك دوت نت. 

٤‏ ١.أساسيات‏ ۷0۴۴ لمبرمجي سي شارب. 


لتفاصيل أكثر عن هذه الكتب ومضمونها وأسعارها وأماكن بيعها: 
http://mhmdhmdy.blogspot.com/2010/09/blog-post 9555.html‏ 





- برمجة قواعد البيانات ب .Entity Framework‏ 


- إنشاء تقارير Report Viewer‏ و .Crystal Reports‏ 
- برمجة مواقع الويب ب .ASP.NET MVC‏ 

- المواضيع المتقدمة في برمجة إطار العمل. 

- الوسائط المتعددة في ۷۴۴. 


Windows Universal Applications برمجة مشاريع‎ - 


سجلوا إعجابكم بصفحتي البرمجية لمتابعة صدور هذه الكتب بإذن الله» والاستفادة 
بالملاحظات البرمجية العملية التي أنشرها على الصفحة: 
https:/www.facebook.com/vbandcsharp‏ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
آمين يا رب العالمين 


محتويات الكتاب 


ه مقدمة 
ه لمن هذا الكتاب 
ا 
تركيب قواعد البيانات Database Structure‏ 
قاعدة البيانات 
الجداول و1261 


قواعد البيانات المترابطة Relational Databases‏ 
العلاقات Relations‏ 

Constraints القيود‎ 

العروض 5/1675 

الفهارس 120125 


5 
قواعد بيانات ووءعع40م 


إنشاء الجداول بتطبيق ووعع ىر 

إنشاء علاقات بين الجداول 

إنشاء قيد Constraint‏ 

ضغط قاعدة البيانات Database Compacting‏ 
متصفح الخوادم Server Explorer‏ 

الاتصال بقواعد بيانات ووعععم 


ا 
قواعد بيانات SQL Server‏ 


Management Studio Express إعداد‎ 

لاء قاعدة انات کول سير فو 

أنواع البيانات في سيكويل سيرفر 

إنشاء. العلاقات في سيكويل سيرفر 

التحكم في خادم سيكويل 

توصيل وفصل قاعدة بيانات 

إنشاء قاعدة بيانات سيكويل سيرفر في دوت نت 
الاتصال بقواعد بيانات SQL Server‏ 

إنشاء الفهارس 5ع12010 

إنشاء القيود Constraints‏ 


۸ 
۲۰ 


۲۲ 


۳٣ 


ءءء 
لغة الاستعلام المركبة Structured Query Language (SQL)‏ 


3 Query Builder باني الاستعلام‎ 
Selection Queries استعلامات التحديد‎ 

SELECT Statement جملة التحديد‎ 

Aggregate functions دوال التجميع‎ 

عمليات الربط 1015 5001 

Action Queries استعلامات الأداء‎ 

حذف الصفوف باستخدام الأمر DELETE‏ 

إدراج سجلات جديدة باستخدام الأمر INSERT‏ 

تحرير السجلات الموجودة باستخدام الأمر UPDATE‏ 

التحرير المتتابع للسجلات« باستخدام الأمر UPDATE .WRI1TE‏ 

Data Definition Language (DDL) لغة تعريف البيانات‎ 
Stored Procedures الإجراءات المخزنة‎ 

إنشاء الإجراءات المخزنة في قواعد بيانات وووعع0م 

دوال ,5001 التي يعرفها المستخدم User Defined SQL Functions‏ 
أنو اع الجداول التي يعرفها المستخدم User-Defined Table Types‏ 


2-6 
ADO.NET تقنية‎ 
۳۲ Client والعميل‎ Server الخادم‎ 
ADO.NET تقنية‎ 
XML لغة‎ 


مزودات قواعد البيانات Database Providers‏ 


كد 
كائن الاتصال Connection Object‏ 


نص الاتصال 16١ Connection String‏ 
2 فئة باني نص الاتصال DbConnectionStringBuilder Class‏ 

# فئة باني نص اتصال سيكيول SqlConnectionString Builder Class‏ 

حفظ نص الاتصال في إعدادات البرنامج وع10)اء5 

44 فئة مقطع نصوص الاتصال ConnectionStringsSection Class‏ 

44 فئة إعدادات نص الاتصال Class‏ 161285 001611015111185 

هه واجهة الاتصال بقواعد البيانات IDbConnection Interface‏ 

DbConnection Class ة الاتصال‎ © 


4 فئة اتصال سيكيول Class‏ 501002261102 
$ فئة خطأ سيكيول Class‏ 501151101 


دلا 
كائن الأمر Command Object‏ 


ه- واجهة أمر قاعدة البيانات IDbCommand Interface‏ ۷۳ 
فئة أمر قاعدة البيانات DbCommand Class‏ 

4 فئة أمر سيكويل SqICommand Class‏ 

تمرير القيم إلى جمل الاستعلام 

SQL Injection دس الاستعلامات‎ 

Parameters المعاملات‎ 

# فئة مجموعة معاملات قاعدة البيانات DbParameterCol1ection‏ 
4 فئة مجموعة معاملات سيكويل SqIParameterCollection Class‏ 
©-ه واجهة معامل البيانات IDataParameter Interface‏ 

ت واجهة معامل بيانات قاعدة البيانات IDbDataParameter Interface‏ 
2 فئة معامل قاعدة البيانات DbParameter Class‏ 

$ فئة معامل سيكويل SqIParameter Class‏ 


A 
DataReader قارئ البيانات‎ 


ت واجهة سجل البيانات Interface‏ 110212162010 حل 
# فئة سجل البيانات DbDataRecord Class‏ 

ص واجهة قارئ البيانات Interface‏ 110212162063 

# فئة قارئ البيانات DbDataReader Class‏ 

۶ فئة قارئ بيانات سيكويل Class‏ 501526816206 


6 
موصل البيانات DataAdapter‏ 


0 واجهة موصل البيانات IDataAdapter Interface‏ 1۳ 
ت واجهة موصل بيانات قاعدة البيانات IDbDataAdapter Interface‏ 

%4 فئة موصل البيانات DataAdapter Class‏ 

© فئة موصل بيانات قاعدة البيانات DbDataAdapter Class‏ 

# فئة موصل بيانات سيكويل SqIData Adapter Class‏ 


القضارع :على تيت البياناك 

ا معالج إعداد موصل البيانات Data Adapter Configuration Wizard‏ 
فئة باني أوامر قاعدة البيانات DbCommandBuilder Class‏ 

4 فئة باني أوامر سيكويل SqICommandBuilder Class‏ 

ت واجهة مجمو عة خرائط الجداول ITableMappingCo1lection‏ 

فئة مجمو عة خر lئط‏ الجداول DataTableMappingCollection Class‏ 
ته واجهة خريطة الجدول ITableMapping Interface‏ 

© فئة خريطة الجدول DataTableMapping Class‏ 

ت واجهة مجموعة خرائط العمود IColumnMappingCollection‏ 

© فئة مجموعة خرائط العمود DataColumnMappingCollection‏ 

ص واجهة خريطة العمود IColumnMapping Interface‏ 

24 فئة خريطة العمود DataColumnMapping Class‏ 


۰ا 


Provider Factories مصانع المزودات‎ 


© فئة مصانع المزودات DbProviderFactories Class‏ تف 
$ فئة مصنع المزود DbProviderFactory Class‏ 

الطبقات المتعددة وم N-1‏ 

فئة عداد مصادر البيانات DbDataSourceEnumerator Class‏ 

4 فئة عداد مصادر بيانات سيكويل سيرفر SqIDataSourceE1Uerator‏ 


اكد 
مجموعة البيانات 122142561 


4 فنئة مجموعة البيانات 1955© DataSet‏ نينا 
اد المعالج السحري لإنشاء مجموعة البيانات Generate DataSet Wezard‏ 

إنشاء مجموعات بيانات خاصة Custom DataSet‏ 

حفظ بيانات الشجرة في مجموعة البيانات 

و فئة موصل الجدول Table Adapter Class‏ 

4 فئة مدير موصلات الجداول TableAdapter Manager‏ 


-۲- 
الجداول والعلاقات والقيود 


# فئة أساس مجمو عة البيانات الداخلية  InternalDataCollectionBase Class‏ T؟؟‏ 
فئة مجمو عة الجداول DataTableCollection Class‏ 

# فئة جدول البيانات DataTable Class‏ 

4 فئة مجموعة الصفوف DataRowCollection Class‏ 

4 فئة صف البيانات DataRow Class‏ 

© فئة مجموعة الأعمدة DataColumnCollection Class‏ 
4 فئة عمود البيانات DataColumn Class‏ 

2 فتة قارئ جدول البيانات DataTableReader Class‏ 

© فئة مجموعة العلاقات DataRelationCollection Class‏ 
6 فئة العلاقة DataRelation Class‏ 
فئة مجموعة القيود ConstraintCollection Class‏ 

Constraint Class فئة القيد‎ 2 

4 فئة قيد تفرد UniqueConstraint Class‏ 

2 فنئة قيد المفتاح الثانوي ForeignKeyConstraint Class‏ 


-١ *-‏ 
عروض البيانات 571685 10262 


۳4۲ BindingList [terface واجهة قائمة الربط‎ ٥ 
ITypedList Interface ص واجهة القائمة محددة النوع‎ 

4 فئة مدير العرض DataViewManager Class‏ 

© فئة إعدادات العرض DataViewSetting Class‏ 

صد واجهة ربط قائمة العرض BindingList View Interface‏ 

فئة واصف ترتيب القائمة ListSortDescription Class‏ 


۳ 


Data View Class فئة عرض البيانات‎ # 

صد واجهة الكائن القابل للتحرير IEditableObject Interface‏ 

ص واجهة التنبيه بتغير خاصية INotifyPropertyChanged Interface‏ 
فئة عرض صف البيانات DataRow View Class‏ 


ا- 
ربط البيانات Data Binding‏ 


ت واجهة المكون القابل للارتباط a IBindableComponent 1nterfac‏ 
4 فئة مجموعة الارتباطات BindingsCollection Class‏ 

4 فئة مجموعة ارتباطات الأداة ControlBindingsCollection Class‏ 

Binding Class َة الارتباط‎ © 

8 سجل معلومات عنصر الربط BindingMemberInfo Structure‏ 

4 فئة محتوى الربط BindingContext Class‏ 

فنئة أساس مدير الربط Class‏ 3038618256]/اع متلمز8 

۶۶ فئة مدير الخاصية PropertyManager Class‏ 

44 فئة مدير التسلسل CurrencyManager Class‏ 

ربط الآدوات كى رقت التضهيم 

Binding List Boxs ربط مربعات القوائم‎ 

ا معالج تهيئة مصادر البيانات Data Source Configuration Wizard‏ 
متصفح مصادر البيانات 

هه واجهة مزود مدير التسلسل ICurrencyManagerProvider Interface‏ 
ص واجهة إلغاء إضافة الجديد ICancelAddNew Interface‏ 

ص واجهة إطلاق أحداث التغير IRaiseltemChangedEvents Interface‏ 
4 فئة قائمة الربط عامة النوع BindingList(Of 1) Class‏ 

© واجهة مصدر القائمة IListSource Interface‏ 

4 فئة مصدر الربط BindingSource Class‏ 

4 فئة مساعد ربط القوائم ListBinding Helper Class‏ 

$ فئة موجه الربط BindingNavigator Class‏ 


300 
جدول عرض البيانات DataGrid View‏ 


# فئة جدول عرض البيانات DataGridView Class‏ د 
التعامل مع أعمدة جدول العرض 

التعامل مع صفوف جدول عرض البيانات 

التعامل مع خانات جدول عرض البيانات 

التعامل مع جدول العرض 

التعامل مع جدول العرض في الوضع الافتراضي 1/17601211/006 

تحسين أداء جدول العرض 

Shared Rows الصفوف المشتركة‎ 

تقسيم جدول العرض إلى صفحات عمزع70 


ملحق ١‏ 
الفنات التي يستخدمها جدول عرض البيانات 


#© فئة عنصر جدول العرض Class‏ 1231306110571615131650624 6 
# فئة نطاق جدول العرض DataGrid ViewBand Class‏ 

© فئة أساس المجموعة BaseCollection Class‏ 

4 فئة مجموعة أعمدة الجدول DataGridViewColumnCollection‏ 

فئة عمود جدول العرض DataGridViewColumn Class‏ 

4 فئة عمود مربعات النصوص DataGrid ViewTextBoxColunn‏ 

فئة عمود الأزرار DataGridViewButtonColumn Class‏ 

4 فئة عمود مربعات الاختيار DataGridViewCheckBoxColumn Class‏ 
24 فئة عمود الصور DataGridViewImageColumn Class‏ 

© فئة عمود الوصلات DataGridViewLinkColumn Class‏ 

2 فئة عمود القوائم المركبة DataGrid ViewComboBoxColumn‏ 

فئة مجموعة صفوف جدول العرض DataGrid ViewRowCol1ection‏ 
فئة صف جدول العرض DataGridView Row Class‏ 

فئة خانة جدول العرض Class‏ 611 12318011057166 

4 فئة خانة مربع النص Class‏ 611 80:0]ره 103201105716991 

$% فنئة خانة الزر DataGridViewButtonCel1 Class‏ 

ص واجهة خانة التحرير IDataGridViewEditingCe11 Interface‏ 


2 فئة خانة مربع الاختيار DataGridViewCheckBoxCe11 Class‏ 
4 فئة خانة الصور DataGridViewImageCell Class‏ 
4 فئة خانة الوصلة DataGridViewLinkCel| Class‏ 


6 


4 فئة خانة القائمة المركبة Class‏ 1021200110171650012060107200611 

ت واجهة أداة التحرير IDataGridViewEditingControl Interface‏ 
2 فئة أداة تحرير مربع النص DataGridViewTextBoxEditingContr01]‏ 
© فئة أداة تحرير القائمة DataGridViewComboBoxEditingContro1‏ 
© فئة الخانة الرئيسية DataGridViewHeaderCel| Class‏ 

© فئة خانة رأس العمود DataGridViewColumnHeaderCe1|‏ 

4 فئة الخانة العلوية اليسرى DataGridViewTopLeftIHeaderCe11‏ 

فئة خانة رأس الصف DataGridViewRowHeaderCel1‏ 

© فئة طراز خانة جدول العرض DataGrid ViewCe11ISty1e Class‏ 

© فئة طراز الحافة المتطور DataGridViewAdvancedBorderStyle‏ 


2-152 
شبكة البيانات DataGrid‏ 


ص واجهة خدمة التحرير ٤ IdataGridEditingService Interface‏ 
44 فئة طراز شبكة البيانات DataGridTableStyle Class‏ 

ق و اجه الث ثبوسة بتخر بحر عمسو ال بكة البياك هات 
IDataGridColumnStyleEditingNotificationService Interface‏ 
$ ئة طراز العمود DataGridColumnStyle‏ 

4 فئة عمود النصوص DataGridTextBoxColumn Class‏ 

فئة العمود المنطقي DataGridBoo1Column Class‏ 

5 سجل خانة الشبكة DataGridCell Structure‏ 

2 فئة شبكة البيانات Class‏ 1031806710 


-۷- 
Data Repeater مُكرّر البيانات‎ 


فئة مكرر البيانات DataRepeater Class‏ 
استخدام مكرر البيانات في الوضع الافتراضي 
44 فئة عنصر مكرر البيانات DataRepeaterItem Class‏ 
ظ ۲ 
أنواع بيانات سيكويل المدارة 
Managed SQL Data Types‏ 
8 سجل القيمة المنطقية SqlBoolean Structure‏ 1/4 
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ا سجل الوحدة الثنائية Structure‏ 501836 

5 سجل الأعداد العشرية SqlDecimal Structure‏ 
# فئة الحروف Class‏ 5010215 

SqIString Structure سجل النص‎ 5 

5 سجل البيانات الثنائية SqlBinary Structure‏ 

4 فئة الوحدات الثنائية وو12© 50183765 

SqIXmI Class "XML" فنة‎ © 

حفظ الملفات خارج قاعدة البيانات 

فئة مجرى بيانات سيكويل SqIFileStream Class‏ 


ملحق: ۳ 
إعداد تطبيق قواعد البيانات على جهاز العميل 
إعداد تطبيق قواعد البيانات على جهاز العميل V۰.۷‏ 
ملاحظات حول استخدام SQL Server Express‏ ۷.۹ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» واهزم أعداءنا وخلصنا من عملائهم 
آمين يا رب العالمين 


هو 


بسم اللهء والحمد لله والصلاة والسلام على رسول الله» وبعد: 
تعتبر قواعد البيانات القلب المركزي في معظم أنواع المشاريع» سواء كانت تعمل 
على سطح المكتب م2»510 أو موقع ويب 516 ا٥۷‏ أو شبكة )اه Nw‏ أو 
جهاز يدوي محمول.. لهذا يعتبر تعلم كيفية إنشاء قواعد البيانات والتعامل معها 
أمرا لا غنى عنه لتنفيذ المشاريع التجارية والإدارية والعمليةء التي تتيح للمستخدم 
استرجاع البيانات وتعديلها وحفظها والبحث فيها بمختلف الطرق. 
ويبدأ هذا الكتاب الرحلة معك من الصفرء ليعرفك على المفاهيم الأساسية اللازمة 
للتعامل مع قواعد البيانات» وكيف تنشئها في Access‏ و 2008 «SQL Server‏ 
وكيف تكتب الاستعلامات التي تحصل على البيانات منها باستخدام لغة 11[ 50. 
بعد هذا يلمك الكتاب كيف تقعامل تسع قرا عد البياتاك من داخل مشاويع يكير ال 
بيزيك دوت نت باستخدام تقنية '41(0.721171» لتستطيع الاتصال بقاعدة البيانات» 
وطلب السجلات منهاء وكيف تقوم بحفظها مرة أخرى في قاعدة البيانات إذا دخلت 
عليها أية تعديلات. 
ويعلمك الكتاب أيضا كيف تعرض البيانات للمستخدم من خلال تقنية الربط 
8 ويشرح بالتفصيل أهم الأدوات المخصصة لهذا الغرضء مثل موجه 
الربط BindingN av gator‏ ومصدر الربط 81001285601106 وجدول العرض 
ang DataGridView‏ البيانات .DataRepater‏ 
ويشرح الكتاب بالتفصيل أكثر من ٠١‏ مشروعا متنوعا تغطي محتوياته» لتتعلم من 
خلالها: 
- كيف تحصل على البيانات من قواعد البيانات بمختلف الطرق»› سواء 
باستخدام قارئ البيانات 12381263061 أو موصل البيانات 
4011 أو موصل الجدول Table Adapter‏ . 
- كيف تحتفظ بالبيانات في الذاكرة, باستخدام مجموعة بيانات )10312561 
سواء كانت عادية أو محددة النوع .Typed‏ 
- كيف تنقل البيانات بين نوعين مختلفين من قواعد البيانات. 
- كيف تحفظ البيانات الثنائية ه5 Binary‏ في ملفات مستقلة على الخادم 
خارج قاعدة البيانات في 2008 Server‏ اSQ.‏ 


1۸ 


- كيف تعرف المعاملات كإعاعمصهإه۲ والمعاملات الجدولية 
5 13616-1731166» وكيف تستخدمها لتمرير البيانات إلى 
الإجراءات المخزنة في 2008 1ع157ع5 501. 

- كيف تحمي قاعدة البيانات من القراصنة الذين يحاولون دس الاستعلامات 
Q1 0‏ من خلال مشروعك. 

- كيف تقرأ البيانات الثنائية والنصية الضخمة تتابعيا 560116412117 على 
صورة أجزاء في 2008 .SQL Server‏ 

- كيف تنشئ الإجراءات المخزنة في ووععA.‏ 

- كيف تحفظ البيانات في ملف ۷1× وكيف تستعيدها منه مرة أخرى. 

- كيف تستخدم مخط ط ]×۷× لإنشاء مجموع ات بيانات خاصضشة 
Custom DataSet‏ لا تعتمد على قاعدة بيانات. 

- كيف تتعامل مع علاقة واحد بمتعدد «One-To-Many Relation‏ 
وعلاقة متعدد بمتعدد 16619610 ›Many-10-Many‏ والعلاقة الذاتية 
.Self Relation‏ 

- كيف تستخدم مصانع المزودات 120101165 إمd¡رها۴‏ لكتابة فئات عامة 
قادرة على التعامل مع أي نوع من قواعد البيانات» مما يختصر الكود الذي 
تكتبه؛ و يمهد لك الطريق لإنشاء مشاريع متعددة الطبقات 
.N-Tier Applications‏ 

- كيف تحل مشاكل تصارع أكثر من مستخدم على حفظ البيانات في نفس 
اللحظة باستخدام التطابق المتفائل .Optimistic Concurrency‏ 

- كيف تعرض البيانات في اللافقات ومربعات النص والقوائم والجداول: 
و كت دول كل هذه العقاضين فنا 

- كيف تنشئ أنواعا جديدة من أعمدة جدول العرض» تعرض خاناتها أداة 
اختيار التاريخ أو شجرة منسدلة أو أي نوع آخر تريده من الأدوات. 

- كيف تجعل جدول العرض يعمل في الوضع الافتراضي 11006 Virtua]‏ 
وكيف تضيف إليه تقنية تقسيم السجلات على صفحات ع12ع22. 

- كيف تنشئ قالبا لعرض كل سجلء وكيف تكرر عرضه باستخدام مكرر 
البيانات .DataRepeter‏ 
كيف تستخدم مكرر البيانات في الوضع الافتراضي 1/1006 1/111021. 

وغير هذا الكثير. 


Kok 


ويغطي هذا الكتاب بالتفصيل حوالي ٠٠١‏ واجهة وفئة وسجلا من مكتبة إطار 
العمل» مخصصة للتعامل مع تطبيقات قواعد البيانات» شارحا خصائص ووسائل 
وأحداث هذه المكونات بالتفصيل.. لهذا يعتبر الكتاب مرجعا مفصلا مبوباء يمكن 
لقارئه الرجوع إليه عند البحث عن تفاصيل أي فئة أو خاصية أو وسيلة أو حدث»ء 
في نفس الوقت الذي يجعله صالحا للقراءة ككتاب تعليمي عملي مرتب من الأسهل 
إلى الأصعبء ينقل إلى المبرمج في صفحات معدودات خبرة سنوات في برمجة 
تطبيقات قواعد البيانات» ويرشده إلى كيفية حل المشكلات غير المتوقعة التي 
تواجهه في هذا المجال» وكيف يحسن أداء برنامجه بتوفير أكبر قدر من الذاكرة 
وكيف يحافظ على كفاءة خادم البيانات» بتقليل عدد الاتصالات ووقت كل اتصال 
بقدر الإمكان. 

باختصار: هذا هو الكتاب الذي تبحث عنه. 


والله ولي التوفيق 


لمن هذا الكتاب: 
رغم أن هذا الكتاب يفترض أن قارئه لا يمتلك أية معرفة مسبقة بقواعد البيانات 
والبرامج التي ينشئها بهاء فإنه على الجانب الآخرء يشترط في قارئه أن يكون على 
دراية بلغة فيجيوال بيزيك دوت نتء وأن يجيد المتطلبات التالية: 
.Functions‏ 
- أساسيات ومفاهيم البرمجة الموجهة بالكائنات 00۲)» كالفنات وعووهاإا٣C‏ 
والواجهات Interfaces‏ والوراثة .Inheritance‏ 
75 والملفات و1116 وفئات معلومات الثقافة .CultureInfo‏ 
- أساسيات التعامل مع مشاريع الويندوزء والأدوات المختلفة كمربع النص 
e×)8 0×‏ 1 ومربع الاختيار ع1160عع') والقوائم ویز . 
فإذا لم تكن تجيد هذه الأساسيات» فننصح بقراءة القسم الأول من كتابنا "المدخل 
العملي السريع إلى فيجوال بيزيك دوت نت"» فهو يغطي هذه المواضيع باختصار 
الكتاب» فيشرح مشروع قواعد بيانات كاملا مكتوبا بتقنية 1[ 50 10 1100 وهي 
غير مشروحة في الكتاب الذي تقرؤه الآن.. وهذا معناه أن كتاب المدخل العملي 
مكمل لهذا المرجع»ء فهو من جهة يشرح مشروع قواعد بيانات واحدا كبيرا بينما 


يستعين المرجع الذي بين يديك بعشرات المشاريع الصغيرة لشرح محتواه» كما أن 
هذا المرجع يشرح تقنية ADO.NET‏ بينما يعطيك كتاب المدخل العملي فكرة 
جيدة عن استخدام النموذج التصوري 210061 6021م00206) باستخدام تقنية 
.LinQ To SQL‏ 


الرموز المستخدمة في هذا الكتاب: 


.Structure سجل‎ 

فئة وو012. 

.Interface واجهة‎ 

.Constant ثابت‎ 

خاصية 117م7]0 يمكنك قراءة أو تغيير قيمتها. 
خاصية للقراءة فقط .Read Only Property‏ 


لقاغما HES‏ لي 








وسيلة .Method‏ 
دم | 
حت | معامل .Operator‏ 
كي |[ حدث أارورم]. 
جه هذا العنصر مشترك 0ع512: يمكن استخدامه عبر اسم الفئة مباشرة. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكانء واهزم أعداءنا وخلصنا من عملائهم 
آمين يا رب العالمين 






































حك 
تركيب قواعد البيانات 


Database Structure 


سنتعرف في هذا الفصل على أهم التعريفات والمفاهيم الأساسية التي تلزمنا للتعامل 
مع قواعد البيانات في باقي فصول هذا الكتاب. 


قاعدة البيانات: 
قاعدة البيانات Database‏ هي ملف أو مجموعة من الملفات» تستخدم لتخزين 
البيانات ۽ التي تربطها علاقات معيّنة»؛ مثل الجداول.. وتتميز قاعدة البيانات عن 
الملفات العادية بو جود برامج معينة للتعامل معهاء > مما يجعل حفظ البيانات 
وقراءتها والبحث فيها أمورا أكثر سهولة وتنظيمًاء وخالية من الأخطاء.. هذه 
البرامج تسمّى "أنظمة إدارة قواعد البيانات": 
Database Management Systems (DBMS)‏ 

و ی و البيانات» تبعا للشركة التي تنتجها والبرامج التي 

تنشئهاء وطريقة تنسيق البيانات المحفوظة في ملف قاعدة البيانات.. فهناك ‏ على 
سبيل المثال - قواعد بيانات ووعن40 وقواعد بيانات S۷۵۲‏ 501 وهما من 
إنتاج ميكروسوفت» وهناك قواعد بيانات ع1ع20172 و ,320375001؛ وغيرها من 
برامج قواعد البيانات من إنتاج شركات أخرى. 
ومهما كان نوع قاعدة البيانات التي تتعامل معهاء ومهما كانت طريقة تخزينها في 
الملفء فإن كل قواعد ا تتبع مان Es‏ 


Query Le (SQL)‏ 110 5» وهي لغة خاصة تستخدم لمك 
واسترجاع وتحديث البيانات الموجودة في قواعد البيانات. 
وتحتوي قاعدة البيانات على أنواع مختلفة من العناصرء منها: 

- الجداول وع1ط12. 

.Relations العلاقات‎ - 

.Constraints القيود‎ - 

- العروض 171675. 


الجداول 12165: 

تتركب قاعدة البيانات في الأساس من مجموعة من الجداول» هي التي يتم تخزين 
البيانات بها.. فإذا لم تحتو قاعدة البيانات على أي جداولء كانت فارغة بلا قيمة. 
فمتلاء لو لديك قاعدة بيانات خاصة بمكتبة» فسيوجد بها جدول يحتوى على عناوين 
الكتب الموجودة في المكتبة (وليكن اسمه 800[15): وجدول آخر يحتوى على 
أسماء مؤلفي هذه الكتب (وليكن اسمه 4:114015)» وجدول ثالث يحتوى على 
أسماء دور النشر التي نشرت هذه الكتب (وليكن اسمه 15هعط115طنا©). 

ويتكون كل جدول من: 


أ. أعمدة ورررورن01© (وتسمی حقولا 716105 أيضا): 
ويشبه العمود المتغيرات في لغات البرمجة» فله اسم ونوع.. وتختلف أسماء 
أنواع البيانات اختلافا طفيفا من قاعدة بيانات إلى أخرىء لكنها في النهاية 
تشبه أنواع البيانات الموجودة في لغات البرمجةء مثل الأعداد الصحيحة 
عع والأعداد الطويلة عمم.] وغيرها. 
وعند إنشاء الجدول» يجب تصميم الأعمدة بشكل صحيح لمراعاة التالي: 
-١‏ أن يكون اسم العمود معبرا عن البيانات التي سيتم تخزينها فيه. 
- أن يتم اختيار نوع البيانات المناسب لحفظ بيانات هذا العمودء 
بحيث: 
- لايكون كبيرا جدا فيهدر مساحة كبيرة على القرص الصلب 
ويبطئ من عمليات نقل البيانات عبر الشبكة. 
- ولايكون صغيرا جدا فيعجز عن استيعاب بعض البيانات 
الهامة» مما يسبب أخطاء في البرامج التي تحاول الكتابة في 
الجدول» أو يمنعها من كتابة بعض البيانات الهامة إن كانت 
هذه البرامج مصممة جيدا لمعالجة الأخطاء التي تحدث., 


ب. صفوف 120188 (وتسمى سجلات 8٥٥0۲‏ أيضا): 
يحتوي الجدول على صفوف» كل صف منها يعتبر وحدة بيانات مستقلة» 
تحفظ القيم فيها تحت كل عمود من أعمدة الجدول.. فمثلا: لو لديك جدول 
خاص بتلاميذ إحدى المدارس» فسيحتوي هذا الجدول على أعمدة تمثل رقم 
الطالب واسمه وعمره وفصله» وسيكون لكل تلميذ صف (سجل) في هذا 
الجدول يحتوي على المعلومات الخاصة به» كما هو موضح: 


۳ 





Class | Age Name ID 
1 ۱۲ أحمد على‎ ١ 
58 ١ و‎ ۲ 
١ 1 شريف عمران‎ 














ويمكن أن يحتوي الجدول على مئات أو آلاف الصفوف تبعا لاحتياجك.. 
وتتحكم العوامل التالية في الحد الأقصى من الصفوف المسموح بحفظه في 
جداول قاعدة البيانات: 


-١ 


مساحة التخزين المتوفرة على القرص الصلب الذي توجد عليه قاعدة 
البيانات.. وإن كانت بعض أنواع قواعد البيانات تسمح بتقسيم ملفاتها 
على أكثر من قرص صلب» للسماح بحفظ ملايين السجلات 
نوع قاعدة البيانات.. حيث إن بعض أنواع قواعد البيانات مثل 
6ع مصممة للتعامل مع قواعد بيانات صغيرة نسبياء لهذا ينصح 
بألا تزيد عدد السجلات المحفوظة فى قاعدة البيانات الخاصة بها عن 
١5‏ الف سكل أو یون سيل غل أقضس, تقذير: | أعوف أن هذا 
يبدو رقما ضخما بالنسبة لك» ولكن في قواعد البيانات العملاقة هذا رقم 
في غاية التفاهة» وقواعد بيانات ه5157 ,5001 و 022016 تتعامل مع 
سجلات تتجاوز عشرات وربما مئات الملايين! 
نوع العمليات التي تجريها على الجدول.. فلو كنت تحتاج إلى إجراء 
عمليات كثيرة على الجداول» وكان هناك عدد كبير من المستخدمين 
الذين يتعاملون مع هذه الجداول في نفس اللحظةء فإن ضخامة أحجام 
الجداول تؤدي إلى إبطاء نقل البيانات وإبطاء عمليات الإضافة 
والحذف والبحث.. في مثل هذه الحالة ينصح بتقسيم الجدول إلى 
جداول أصغر فيما يعرف باسم عملية التطبيع 71011721122610.. هذه 
العملية يمكن أن تتم 
0 رأسيا: ena Ea,‏ 
باستخدام رقم السجل 1D‏ والذي يعرف في هذه الحالة باسم المفتاح 
.Key‏ 
ب. أفقيا: وذلك بتقسيم الصفوف على أكثر من جدول تبعا لعامل 
مشترك بينها.. مثلا: يمكن تقسيم الصفوف على حسب تواريخهاء 
وبدلا من أن يكون لديك جدول واحد لكل السنوات» يكون لديك 
جدول لكل سنة (هذا مناسب لجدول التلاميذ على سبيل المثال).. 
كما يمكنك أن تقوم بعملية تطبيع لقاعدة البيانات كلهاء بتقسيمها إلى 
عدد من قواعد البيانات» تبعا للعام» أو المنطقة الجغرافية إلخ. 

















ويتحكم نوع المشروع الذي تتعامل معه وطبيعة بياناته» في كيفية حل 
مشاكل تضخم قواعد البيانات» وكيفية تقسيمها.. لهذا من المهم أن تحلل 
النظام الذي تتعامل معه جيدا لاختيار أكفأ تصميم لقاعدة البيانات منذ 
البداية» لأن محاولة حل مشكلة ظهرت بعد عدة سنوات من العمل على 
النظام» قد تكون مكلفة جدا ومضيعة للوقت والجهد» وربما تؤدي إلى إعادة 
كتابة البرامج كلها منذ البداية! 


قواعد البيانات المترابطة :Relational Databases‏ 
لو كانت لدينا قاعدة بيانات للمكتبات ودور النشرء فسيحتوي جدول الكتب 78001 
على عدة أعمدة لتخزين بعض المعلومات عن كل كتاب» مثل اسمه؛ وعدد 
صفحاته» وموضوعه وسعره... إلخ. 
يجب أيضا أن يحتوي جدول الكتب على معلومات عن مؤلف كل كتاب» مثل اسمه 
ونبذة عنه وبريده الإلكتروني وهاتفه» ليستفيد بها الناشر عندما يريد الاتصال به.. 
فكيف يا ترى نحفظ هذه المعلومات؟ 
بداهة» ليس من الذكي وضع كل هذه المعلومات في جدول الكتب» لأنه سيحتوى 
بالتأكيد على أكثر من كتاب لنفس المؤلف» مما سيسبب المشاكل التالية: 
- تكرار بيانات المؤلف أكثر من مرة» مما يزيد من حجم قاعدة البيانات 
ويبطئ عمليّات البحث. 
- إرهاق المستخدم الذي يدخل البيانات» بسبب تكرار كتابة بيانات نفس 
المؤلفين مرارا وتكرارا. 
- احتمال حدوث خطأ في إدخال بيانات المؤلف المكررة؛ مما يؤدي لتضارب 
في بيانات نفس المؤلف. 
- عند تغير رقم هاتف المؤلف» يجب تعديل هذا في كل سجلات الكتب! 
- عند البحث عن بيانات المؤلف» سنحصل على أكثر من سجل بها نفس 
التفاصيل بلا فائدة! 
والأمر نفسه بالنسبة لبيانات دار النشر التي نشرت الكتاب» فمن المتوقع وجود 
مئات الكتب لكل دار نشرء ومن العبث تكرار معلومات مثل اسم وعنوان وهاتف 
دار النشرء واسم الناشر أو مدير الدار... إلخ مع كل كتاب! 
إذت فما هو الكل المثاسي ليذه المشكلة؟ 
كما ذكرنا من قبل» يجب إجراء عملية تطبيع 710100211723610 لهذه البيانات» 
وذلك بتخصيص جدول للمؤلفين 811015 يحتوى على سجل واحد لكل مؤلف 
لنحفظ فيه بياناته الأساسية» وجدول للناشرين وإعطوع ان" يحتوي على سجل 
واحد فقط لكل دار نشر لنحفظ فيه تفاصيلهاء مع ربط جدول الكتب بكل من هذين 
الجدولين.. دعنا نرى كيف نفعل هذا: 








في جدول المؤلفين سننشئ عمودا للرقم المسلسل لكل مؤلف» اسمه (11.. وفي 
جدول الكتب سننشئ عمودا اسمه (4110111» لنضع فيه رقم مؤلف كل كتاب.. 
فمثلا لو كان رقم (توفيق الحكيم) في جدول المؤلفين هو ١ء‏ فإن الخانة 
ut‏ في جدول الكتب لا بذ أن تكون ١‏ لكل من الكتب التالية: 

"شهرزاد" و"الأيدي الناعمة" و"أرني الله" و"شجرة الحكه" 
كما هو موضح في الجدولين التاليين: 














About eMail Phone Author ID 
5 عباس العقاد‎ | ۲ 
5 محمد عبد الحليم‎ 

عبد الله 
. نبيل فاروق - 
أحمد خالد توفيق aktowfik@hotmail.com‏ 5 
محمد حمدي msvbnet@hotmail.com‏ - 

Price | Pages | AuthorID Book ID 
0.۰ 1۰ ١ أرنى الله‎ ١ 
Vo 1° ١ يوميّات نائب فى الآرياف‎ ۲ 
o. 10۰ ١ عصا الحكيم‎ ۳ 
0۰۰ V۰ ۲ سارة‎ ٤ 
o ۳۹ ۲ عبقرية محمد‎ ° 
1٠٠ ۸۰ ۲ عبقرية عمر‎ 
0 ۳. ۳ شجرة اللبلاب‎ ۷ 
is 1۰۰ ٤ مهنتى القتل‎ ۸ 
u ys ٤ الافق القن‎ ۹ 
Yo ١7 ° أسطورة الغرباء‎ ١ 
56 ۷۸ 5 لا تدخلوا شيرود‎ ١ 
06 1 ٦ مجرد طريقة للتفكير‎ 1 
57 ۸۰ ٦ حائرة فى الحب‎ ٤ 
۰ 5 5 نير وشن مق الخلوة‎ 1٥ 














نفس الشيء يمكن فعله بالنسبة لجدول الناشرين» حيث سنضع فيه تفاصيل كل 
الناشرين» ونربط بينه وبين جدول الكتب بإنشاء عمود اسمه (11556111ا2 في 
جدول الكتب. 

والآن» دعنا نؤكد مرة أخرى فوائد هذه العملية: 


۲٦ 
















































































-١‏ توفير مساحة التخزين» فبدلا من تكرار نفس بيانات المؤلفين والناشرين مع 
كل كتاب» صرنا نكرر فقط رقم المؤلف ورقم الناشر. 
؟- تسريع عمليّة البحث.. فمثلا لو أردت البحث عن كل كتب توفيق الحكيم في 
جدول الكتب» فسيكون البحث عن الرقم ١‏ في الحقل (4110111 (وهو 
حقل عددي) أسرع بكثير من البحث في الحقل 41101 (وهو حقل نصي) 
عن الاسم "توفيق الحكيم".. صحيح أننا سنبحث في جدول المؤلفين أولا 
عن "توفيق الحكيم" للحصول على الرقم الخاص به» لكن عدد الصفوف في 
جدول المؤلفين سيكون أقل بكثير من عدد الصفوف في جدول الكتب. 
شرا التعديل و تخ الأخطاء. افر ص هتد أن الموظطفة الذى دل 
أسماء المؤلفين أخطأ وكتب الاسم "توفيق الحكيم" كالتالي: "تفيق الحكيم".. 
في هذه الحالة ما عليه إلا أن يعدل الخطأ مرّة واحدة في جدول المؤلفين.. 
أمّا لو كانت أسماء المؤلفين موجودة في نفس جدول الكتب» فإِنّ تكرار 
كتابة اسم المؤلف يجعل احتمالات الخطإ أكبرء بالإضافة إلى تضييع الوقت 
والجهد في كتابتهاء ومشقة تعديلها كلها! 
وعند استخدام هذا التنظيم» يقال إن هناك علاقة منط[5م11210 بين جدولي الكتب 
والمؤلفين»ء حيث إن الرابط بينهمما هو رقم المؤلف («آ11]01.1لىم 
و ..)Bo0oks.Author1D‏ كما توجد علاقة بين جدول الناشرين وجدول الكتب» 
والرابط بينهما هو رقم الناشر Publisher.1D)‏ و .(Books.PublisherID‏ 
هنا يجب أن نتعرف على المصطلحات التالية: 
- يسمّى الحقل المشترك في كلا الجدولين "حقلا مفتاحيا" 7610 yءK.‏ 
- يسمّى الحقل 11 في جدول المؤلفين باسم "المفتاح الأساسي" 
›Primary Key‏ وذلك لأنه متفرد ueوزول‏ غير قابل للتكرار 
(يجب ألا يتكرر نفس المفتاح لأكثر من مؤلف).. ولا يحتوي الجدول على 
أكثر من مفتاح أساسي واحد. 
- يسمّى الحقل (110111 في جدول الكتب باسم "المفتاح الفرعي" أو 
"المفتاح الدخيل" ره «رع1"0»1؛ لأئه موضوع في هذا الجدول ليربطه 
بجدول آخر.. ويمكن أن تتكرّر بعض القيم في خانات هذا العمود بدون 
أدنى مشكلة (كما في حالة وجود أكثر من كتاب لنفس المؤلف).. ويمكن أن 
يحتوى الجدول على أكثر من مفتاح فرعي تربطه بعدد من الجداول 
الأخرى (كأن يحتوي جدول الكتب على المفتاحين الفرعيين 0۲15 طاںA‏ و 
.(PublisherID‏ 
- يسمّى جدول الموّلفين باسم "الجدول الرئيسي" 1۲ء وجدول أسماء 
الكتب باسم "جدول التفاصيل" 10649119»: حيث يمكنك أن تحصل منه على 
معلومات عن الكتب المتوافرة لكل مؤلف.. وتسمى العلاقة بين الجدولين 
بعلاقة .Master-Details‏ 


- تسمّى عمليّة مطابقة الصفوف بين الجدولين المترابطين باستخدام الحقل 


المفتاحي» بعملية "الربط" ررزمل. . كأن تحاول معرفة اسم مؤلف كتاب 
معيّن» أو أن تحاول أن تعرف كل الكتب التي كتبها نفس المؤلف. 


أنواع العلاقات: 


يوجد أربعة أنواع رئيسية للعلاقات بين الجداول: 


-١ 


علاقة "واحد بمتعدذد"" :One-to-many Relationship‏ 

تسمى العلاقة بين جدول المؤلفين وجدول الكتب في المثال السابق بعلاقة 
"واحد بمتعدد" منطدم1061200 ›0ne-t0-many‏ وذلك لأن مؤلمًا واحدا 
يمكن أن يكون له أكثر من كتاب. 

علاقة "متعدد بمتعدد"" :Many-to-many Relationship‏ 

افترض أن لدينا كتابا اشترك في تأليفه أكثر من مؤلف.. في هذه الحالة لن 
نضع العمود 0۲15 ط) ں۸ في جدول الکتب» وبدلا من هذا سننشئ جدولا 
ثالثا هو جدول "مؤلفو الكتب" 8001258114015.. هذا الجدول يسمى 
جدول الربط 191 م1 أو جدول الاتصال 8116) "ناسل وهو 
يتكون من عمودين فقط: رقم الكتاب (2001211 ورقم المؤلف AuthorID‏ 


: كالتالي‎ 
(لطلل0061ظآ‎  AuthorID 
١ ۲۳ 
١ ١ك‎ 
۲ ۸ 
۳ ۸ 











حيث اشترك المولفان رقما 7 و ٠١6‏ في تأليف الكتاب رقم ١ء‏ بينما قام 
المؤلف رقم ۸ بتأليف الكتابين رقمي ۲ و". . هذه هي علاقة متعدّد بمتعذد 
.Many-to-many‏ 


علاقة "واحد إلى واحد" ©0726-60-026: 

في هذه العلاقة يتم تقسيم السجل الواحد على جدولين» وذلك إذا كان عدد 
أعمدة الجدول كبيرا جداء وكان بعضها قليل الأهمية ونادر الاستخدام» أو 
إذا كانت هذه الأعمدة تحتوي على بيانات سرية» لهذا يجب وضعها في 
جدول خاص ومنح صلاحية التعامل معها لمدير النظام مثلا.. بهذه الطريقة 




















يكون جزء من السجل في الجدول الأول متاحا لكل المستخدمين» وباقي 
السجل في جدول آخر مخصص لمستخدمين بعينهم. 

وفي علاقة "واحد بواحد" يكون كل من المفتاح الأساسي والمفتاح الفرعي 
متفردا Unique‏ غير قابل للتكرار» وبهذا نضمن ارتباط كل مفتاح أساسي 
بمفتاح فرعي واحد فقط. 

وكمثال: افترض أن لدينا جدولا لبيانات الموظفين اسمه وع103:6م120 
يبدو كالتالي: 


Address eMail | Phone Employee | ID 
مجدي نوارة‎ 
ياسر الهواري‎ 


في هذه الحالة سنحتاج إلى جدول آخر نضع فيه اسم المستخدم وكلمة السر 
الخاصة بكل موظف» وليكن اسمه 1036651225510105م1712» وسنربطه 
بالجدول وعع:1058م87 باستخدام مفتاح فرعي اسمه (11ع181200103:6 مع 
جعله مفتاحا متفردا 1[210116: 





nm | | 
































EmployeelD Password USerName ID 
١ 1 ash ١ 
1 5 mgdy ۲ 
اا‎ 57 rshdan ۳ 
٤ ysrhwary 0 


لاحظ أن العمودين 12 و (107:6611م813 في الجدول السابق متماثلان 
(وليكن العمود ([1). 


العلاقة الذاتية :Self-Relation‏ 

في بعض الأحيان يمكن إنشاء علاقة بين سجل من سجلات الجدولء 
وسجل آخر في نفس الجدول.. يسمى هذا بالعلاقة الذاتية 
102 .» حيث يحتوي الجدول على عمود المفتاح الأساسي 
وعمود المفتاح الفرعي معا.. هذا مفيد عند تمثيل أي تركيب هرمي 
كالشجرة ٣e٥‏ . قى هذه الحالة يشير المفتاح الفرعي لكل سجل إلى 
المقتاح الأسائني للسجل الرئيسي الذي ينتمي إليه.. وعلينا تنيع هذه السلسلة 


۲۹ 






































إلى أن نصل إلى سجل رئيسي يعمل كجذرء وفي هذه الحالة يجب أن نضع 
صفرا أو ١-‏ في خانة المفتاح الفرعي» للإشارة إلى عدم وجود سجل 
رئيسي لهذا السجل.. افترض مثلا أن عندنا شجرة العائلة التالية: 














:كام 
۵ شريف 11 ParentlD Name‏ 
هن أحمد كاقل 1 
0 نهى ؟ | شریف ١‏ 
۵ هانى ۳ أحمد ۲ 
ه رشيد 0 نهى ۲ 
O‏ فتحي 5 هانى ١‏ 
۾ عمر 5 | رشيد 
0 نجوى ۷ فتحي ° 
ه تقوى 6 | عمر ١‏ 
هم معاد ۹٩‏ نجوى ۸ 
يمكن تمثيل هذه الشجرة في جدول | ٠١‏ | تقوى ۸ 
واحد كما هو موضح. ١‏ | معان ۸ 


في هذا الجدول» يعمل الحقل (11 كمفتاح أساسيء بينما يعمل الحقل 

ParentD‏ كمفتاح فرعي.. وبهذا يكون من السهل استخراج كل التفاصيل 

المطلوبة لو بدأنا من أي سجل.. مثلا: 

- لمعرفة السجلات الفرعية للسجل الحاليء عليك بالبحث في الحقل 
(16211/ عن الخانات التي تحتوي على القيمة الموجود في الحقل 
غير موجود في الحقل ۴4۲٥٣٤15‏ في أي سجل في الجدول.. بينما 
عمر له ثلاثة أبناءء لأن معرفه 15 = ۸» موجود في الحقل 
(11)مع في السجل رقم ٩‏ والسجل رقم ٠‏ والسجل رقم 1١‏ 

- ولمعرفة السجل الرئيسي للسجل الحاليء يكفي أن نقرأ المععرف 150 
المحفوظ في الحقل (411مع2731 للسجل الحالي.. مثلا: عمر هو ابن 
الرجل الذي سجله يحمل المعرف ١ء‏ (وهو كامل). 

إن هذه أفضل طريقة لتمثيل العلاقات الشجرية؛ فلو حاولت استخدام أكثر 

من جدول لتمثيلهاء فسيكون عليك إنشاء جدول لكل مستوى من مستويات 

الشجرة» وإنشاء علاقات بينهاء وهو أمر غير عملي ويضيع منك وقتا 

أطول في تصمم الجداول» خاصة لو ازداد عدد المستويات الفرعية 

للشجرة؛ كما أن كتابة الكود الذي يتعامل مع مثل هذه الجداول سيكون 

مزعجا ومعقدا!.. انظر كيف يمكن تمثيل الشجرة السابقة بثلاثة جداول: 





















































Grandparents جدول الجدود‎ 
Name ID 
كامل‎ ١ 
Parents جدول الآباء‎ 
GrandParentID Name ID 
١ شزیف‎ ١ 
١ هانى‎ ١ 
١ عق‎ ۴ 
56015 جدول الأبناء‎ 
ParentID Name ID 
١ أحمد‎ ١ 
١ ين‎ ۲ 
۲ رشيد‎ ۳ 
۲ فتحی‎ ٤ 
١ نجوى‎ 5 
۳ تقوى‎ 5 
۳ معاد‎ ۷ 














طبعا سيكون الأمر كارثيا لو أردت تمثيل عدة أجيال أخرى» كالأحفاد 
وأبناء الأحفاد وهلم جرا! 


:Constraints القيود‎ 

ماذا سيحدث لو تم حذف سجل توفيق الحكيم من جدول المؤلفين؟ 

في هذه الحالة ستظل هناك روايات في جدول الكتب تشير إلى سجل توفيق الحكيم؛ 
بينما هو محذوف.. هذا بالتأكيد وضع مثاليّ لحدوث أخطاء و مزعجة في برنامجك» 
لهذا يجب أن تراعي منطقيّة وصحة العلاقات المرجعيّة. وهو مايعرف باسم 
التكامل المرجعي بين الجداول 117ع 11226 اReferentia›‏ فلو قمت بحذف سجل 
توفيق الحكيم من جدول المؤلفين» فيجب عليك أيضا أن تحذف كل الروايات 
والكتب التي ألفها من جدول الكتب. 

وللتأكد من فرض هذا التكامل» يمكننا تعريف ما يسمى بالقيود 00125113115.. 
مثلا: لو أضفت قيد المفتاح الاجنبي ›Foreign-Key Constraint‏ فإن 
قاعدة البيانات سترفض حذف أي مؤلف بينما ما تزال هناك كتب تابعة له.. 
هذا يجبرك على حذف كتب هذا المؤلف أولا قبل أن تقوم بحذفه. 


۲١ 






























































ويوجد قيد آخر نوهنا إليه سابقاء وهو قيد التفرد «Unique Constraint‏ 
وهو ترصن عن الماع لانت للحدول لمان ترد مغرف كل سل 
ويفرض قيد التفرد أيضا على المفتاح الفرعي في حالة واحدة فقط وهي عند 
التعامل مع علاقة واحد بواحد 6ع0-0]-026. 


العرض هو طريقة لعرض بعض البيانات من جدول أو أكثر.. ويمكن أن تحفظ 
طريقة العرض هذه في قاعدة البيانات باسم خاصء إذا كنت تحتاج إلى الرجوع 
إليها أكثر من مرة. 

مثلا: يمكنك أن تنشئ في قاعدة بيانات الكتب عرضا اسمه 65 *» يعرض 
الكتب الأكثر مبيعا. 

لاحظ أن العرض لا يستهلك مساحة في قاعدة البيانات» لأن ما يحدث فعليا هو حفظ 
الاستعلام تزعن0 الذي يجمع بيانات هذا العرضء وعند فتح العرضء يتم تنفيذ هذا 
الاستعلام مرة أخرى لجمع البيانات من الجداول.. هذا يضمن أنك ترى دائما أحدث 
البيانات الموجودة في الجداول. 
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الفهارس وعع1201: 

افترض أئك تريد أن تبحث عن قيمة معيّنة فى أحد الأعمدة» كالبحث متلا عن 
(أحمد خالد توفيق) في حقل المؤلفين.. أوّل ما سيجول بذهنك هو أنّ الحاسب 
سيفحص أسماء المؤلفين واحدا وراء الآخر من البداية إلى النهاية.. ربّما تبدو هذه 
الطريقة سهلة» ولكتها أسوأ طريقة يمكن أن يتمّ البحث بهاء لأنها قد تتسبّب في بطءٍ 
شنيع في أداء البرنامج» خاصّة وأنْ الجدول قد يحتوي على عدد كبير من 
الصفوف» قد يصل إلى عشرات أو مئات الآلاف» وكل خانة من خاناته قد تحتوي 
على نصوص طويلة»؛ وأنت تعرف أن مقارنة عددين تتم بمقارنة الوحدات الثنائية 
و في كل منهما (لهذا يحتاج العدد الصحيح ام مثلا إلى أربع عمليات 
مقارنة)» بينما تحتاج مقارنة نصين إلى مقارنة حروف كل منهماء مما يزيد كثيرا 
من عمليات المقارنةء فقد تحتاج قاعدة البيانات إلى إجراء 0۰ عملية لمقارنة نصين 
اثنين طول أقصرهما ٠١‏ حرفا بافتراض أسوأ حالة ممكنة» وهي تشابه أول ٤۹‏ 
حرفا في النصين!.. هذا مع العلم بأن حقول النصوص قد تحتوي على نصوص 
أطول من هذا بكثير! 

لمثل هذه التحديات» توجد العديد من الطرق لتسريع عملية البحثء تبدأ بترتيب 
العمود أبجديّاء وذلك لأن البحث في عمود مرتب أسرع بكثير من البحث في عمود 
عشوائي» خاصة مع استخدام طريقة بحث جيدة» مثل البحث الثنائي Binary‏ 
Search‏ أو غيره من الطرق. 

ولكن» رغم سرعة عملية البحث بعد الترتيب» إلا إن الترتيب نفسه قد يكون 
مأساة!.. هل تتخيّل كم من الوقت يمكن أن يضيّعه برنامجك لترتيب خمسين ألف 
نص مثلاء يتكون كل منها في المتوسط من 3١‏ حرفا؟.. فما بالك إذن حينما يقوم 
البرنامج بتكرار البحث في نفس العمود أكثر من مرّة؟! 

إذْن:فما الخل؟ 

الحل هو أن نرتب بيانات العمود فى قاعدة البيانات منذ البداية» وبهذا نضمن سرعة 
البحث» دون الحاجة إلى تكرار عملية الترتيب في كل مرة.. لكن هذا يقودنا إلى 
سؤال آخر: وماذا لو كان الجدول يحتوي على أكثر من عمود تحتاج للبحث فيهاء 
فتبعا لأيّ منها سوف نرتب الجدول يا ترى؟!! 

هنا يبرز حل رائع اسمه الفهارس 12016:©5: 

تخيّل أننا طلبنا من قاعدة البيانات إنشاء فهرس لعمود الأسماء في جدول المؤلفين.. 
هنا سيتم ترتيب هذا العمود» مع إنشاء فهرس يحتفظ ببيانات توضح ترتيب كل 
مؤلف.. فمثلاء إذا كان توفيق الحكيم هو المؤلف رقم ١‏ في الجدولء ونبيل فاروق 
هو المؤلف رقم ۷» وأحمد خالد توفيق هو المؤلف رقم ٠٠١‏ فإن الفهرس سيحتفظ 
بمعلومات تفيد بأن أول مؤلف في الترتيب الأبجدي يوجد في الصف رقم ١٠ء‏ يليه 
في الترتيب المؤلف الذي يقع في الصف رقم »١‏ يليه المؤلف الذي يقع في الصف 
رقم 7.. هذا يحقق لنا الفوائد التالية: 
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لاحظ 
للعمود 
م 





ولكن.. 
3 


يمكن استخدام هذا الفهرس لتطبيق خوارزميات البحث على عمود المؤلفين 
وكأنه عمود مرتب» وبالتالي ستكون عمليّة البحث اسرع. 

لن نحتاج إلى إجراء أي تغيير في طريقة عرض البيانات في قاعدة البيانات» 
حيث سيظل ترتيب المؤلفين في الجدول كما هوء وبالتالي سنترك للمستخدم 
حريّة ترتيب البيانات كما يحلو له. 

يمكننا إنشاء أكثر من فهرس لأكثر من عمودٍ في نفس الجدول» ممّا يعني 
قدرتنا على ترتيب كل هذه الأعمدة والبحث فيها. 

سنوفر وقت ترتيب العمود أثناء البرمجة» وإن كان هذا الوقت سيستهلك عند 
إنشاء الفهرس لأوّل مرّة في وقت التصميم.. لاحظ إن إنشاء الفهرس 
والجدول فارغ أو به القليل من الصفوف» يجعل عملية إنشاء الفهرس 
أسرع» وكلما أضفت سجلا جديدا إلى الجدول» يتم تحديث الفهرس لوضع 
هذا السجل في ترتيبه في الفهرس. 

لس ل اه لطع الع 
ا هذه الس ع لد العمود القاتى راسم الدولة مكلذ : 


ملحوظة: 

بمجرد جعل الحقل مفتاحا أساسيا للجدول» يتم إنشاء فهرس لهء نظرا لأن المفتاح 
الرئيسي يستخدم بغزارة في الاستعلامات التي تبحث عن سجلات معينة في 
الجدول» خاصة مع استخدامها في علاقات مع جداول أخرى. 





للأسف لا توجد طريقة مثاليّة» فهناك عيبان أساسيّان للفهارس: 

الفهارس المنشأة يتمّ حفظها في قاعدة البيانات» مما يعمل على زيادة 

حجمها.. لهذا إذا كان حجم قاعدة بياناتك كبيراء فلا بد أن توازن بين 

حاجتك إلى توفير الوقت وحاجتك إلى توفير الحجم.. لكني لا أظن هذه 

مشكلة كبيرة اليوم» مع السعات الهائلة لوسائط التخزين. 

عند تعديل قيمة أي خانة في العمود المفهرسء أو حذف أو إضافة أي 

صف لا بذ من إعادة تحديث الفهارس لمراعاة الاختلاف الذي أحدثه هذا 

التغيير.. مثل هذا الأمر يسبّب عيبا خطيراء هو بطء عمليّات التعديل 

والحذف والإضافة بصورة ملحوظةء تزداد سوءا مع ازدياد طول الجدول» 

ومع تكرار هذه العمليات في برنامجك بشكل كبير.. هنا يجب أن توازن في 

برنامجك» بين حاجتك إلى سرعة البحث وحاجتك إلى سرعة التحديث 

والحذف والإضافة.. لديك هذه الحالات: 

أ- إذا كان ر يقوم بمئات من عمليّات التحديث والإضافة 

والحذف بطريقة متتالية ومن عدد كبير من المستخدمينء بينما لا 
توجد الكثير من عمليات البحثء فلا داعي لإنشاء الفهرس! 
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ب- إذا كنت تستخدم قاعدة بيانات يتعامل معها المستخدمون في معظم 
الوقت لقراءة البيانات وإجراء الاستعلامات وعمليات البحٿث» فإن 
الفهرس سيجعل هذه العمليات أسرع بكثير» ومع قلة عمليات 
التحديث والإضافة والحذف (المتاحة فقط لمدير النظام)» لن يكون 
عبء الفهارس ملحوظا. 

ج- إذا كنت تحتاج إلى كلا النوعين من العمليات في نفس الوقت» 
فيمكنك تقليل العبء الناتج من الفهارس في برنامجك بحيلة 
صغيرة: فعندما تكتب في الكود حلقات التكرار 5م100 أو 
الاستعلامات التي تقوم بتعديل أو إضافة أو حذف مئات أو آلاف 
السجلات على التوالي» فاحذف الفهرس من الجدول قبل بدأ تنفيذ 
هذا الكودء ثمّ قم بإعادة إنشائه مرّة أخرى بعد انتهاء هذه العمليات» 
وبهذا تقلل من عبئه وتستفيد منه في تسريع عمليات البحث في نفس 
الوقت! 
لكن عليك ملاحظة أن هذه الحيلة ستكون خطيرة إذا كان هناك عدد 
كبير من المستخدمين يتعاملون مع قاعدة البيانات في نفس اللحظة. 
وبعضهم يبحث وبعضهم يحذف السجلات!!.. لهذا فأنت الوحيد 

الذي يعرف طبيعة عمل البرنامج وأنسب اختيار لجعله أكفأ ما 

٤ ٤ يمكن.‎ 

وكقاعدة: أنشئ فهارس للحقول النصية التي تتوقع أن يحتاج 

مستخدمو برنامجك للبحث فيها بغزارة. 


وسنتعرّف على كل هذه المفاهيم عمليّاء أثناء إنشاء قواعد البيانات» وأثناء 
استخدامها من خلال برامجنا. 


للا 


قواعد بيانات 00655 ۸ 


لن تستطيع التعامل مع قواعد البيانات» ما لم تكن لديك المقدرة على إنشاء قواعد 
البيانات وما تحتوية من ,جذاول., تال تأخذ فكرة سريعة عن .هذا الأمر, 


انشاء الجداول يتطييق 4©©©559: 


و25 هو أحد تطبيقات 018506 211005011.. لن تجد فارقا يذكر بين 
إصدارات 2000 Access‏ و Access XP‏ و 2003 ..Access‏ لكنك ستجد 
اختلافا كبيرا في واجهة الاستخدام بدءا من 2007 400655.. دعنا هنا نتعامل مع 
Access ×‏ وعليك التعامل مع الفوارق البسيطة بين الإصدارات المختلفة 
افتح تطبيق ووعن40 ومن القائمة "ملف" 1116 اختر "جديد" وج281.. آنا أكتب 
أسماء القوائم بالعربية والإنجليزية لأن البعض لديه واجهة استخدام عربية» 
والبعض لديه واجهة إنجليزية» على حسب النسخة التي أعدها على جهازه. 
ستظهر لك نافذة "ملف جديد" 17116 سه في جانب واجهة التطبيق كما في 
الصورة التالية: 





IA Microsoft Access 
| هلف تصحرير عرض إدراع أدوات إطار تعليمات اکب و زاتما‎ 
١0 2 د | جه 4 |¥ هانةا|91© د‎ ٠ | 5: - | مه و | - هق‎ | FT | قد‎ <>. 
“+ هلف حديد‎ ** × 
2ه مافات...‎ 

حديد سس 

[!2 قاعدة بيانات رغه 

[25 صفحة وصؤل إلى البيانات فارغة 
[23) المشروع (البيانات الموجودة) 

9 المصروع (البيانات الجديد6) 

حديد من ملف موحود 

01 اختيار ملف... 

حديد صن قائب 

[27 قوالب عامة... 

[© قرحب عدى .اممو مم 





زضافة موضع شيكة الاتمال... 
(3] صعنيمات Microsoft Access‏ 
ل] زشهار عند بده التشغيل 


۳٢ 


تحت الشريط "جديد" سم" اضغط الأمر "قاعدة بيانات فارغة" 
Database‏ lankاB..‏ سيظهر لك مربّع حوار "حفظ ملف" «Save-File Dialog‏ 
وهو يطلب منك تحديد اسم قاعدة البيانات وموقع حفظها على الجهاز.. غيّر اسم 
قاعدة البيانات من الاسم الافتراضي إلى ‘""Books.mdb"‏ وقم بحفظها في 
الموضع الذي تريده. 

بعد إغلاق مربّع الحوار ستظهر لك نافذة قاعدة البيانات كما في الصورة التالية: 


A Microsoft Access | 5| ×‏ 
علف تحرير عرض إدراع أدوات إطار تعليمات © اكتب سؤالاً للت ١‏ 
28-١ ©‏ قد |50 | مه وذ | - فق | 5 | - د | © جه + | * ها 2 | هم نه 2 0 | 


01298 ااب (تنسيق ملف 2000 ككععع86) ف 


7[ | × | جدیدت تصميممظ و8 


a 
©[ إنشه جنول باستخدام المعالح‎ 
@[ إنشه جدول بإدخال البيانات‎ 

















جاشر 
انقشر الأمر "انشاء جدول في طريقة عرص التص ميم" 
Create rable in Design View‏ مرتين بالفأرة.. ستظهر لك نافذة تصميم 





إحت| عام 





۲۷ 

















كل ما عليك الآن» هو كتابة أسماء الحقول وتحديد نوع البيانات التي ستضعها في 
كل منها. . تعال نبدأ بتصميم جدول أسماء المؤلفين.. هذا الجدول سيتكوؤن من 

















الحقول التالية: 
اسم الحقل نوع البيانات الوصف 
Description Data Type Field Name‏ 
(ترقيم تشي | المفتاح الرئيسي لهذا الجد 
AutoNumber‏ ح الرئيسي لهذا الجدول 
Author‏ (نص) 1٥×٤‏ | اسم المؤلف 
(رقم) رقم الدولة التي ينتمي إليها 
Number OIE‏ | المؤلف. 
Phone‏ (نص) 166 | رقم هاتف المؤلف. 
About‏ ر ا 
Memo‏ 
٠‏ 4 


0 


سيم ا وا بأسماء أجنبيّة ا هذه الاسماء E‏ في كد الكود في 
اکر يرن هة 0 


بعد أن تنشئ هذه الحقولء قم بما يلي: 





اضغط بزر الفأرة الأيمن على المربّع الرماديّ المجاور للحقل (11» ومن 
القائمة الموضعيّة Menu‏ 1م00 اضغط الأمر "مفتاح أساسي" 
Primary Key‏ لجعل هذا الحقل مفتاحا أساسيًا للجدول.. ستلاحظ ظهور 
رمز المفتاح أمام هذا الحقل.. ستلاحظ كذلك أن الخاصيّة "مفهرس" 
إه>مإ في المنطقة السفلى من النافذة ستتحول إلى "نعم بدون تكرار" 
)٥0 Duplicates)‏ وعلاء وهو شيء متوقع» فلقد اتفقنا أنّ قيم المفتاح 
الأساسي: غين قايلة للتكران, 

اضغط بالفأرة على حقل اسم المؤلف إ0 ا۸ء وفي المنطقة السفلى من 
النافذة غير قيمة الخاصيّة "حجم الحقل" ع517 11611 إلى "١‏ بدلا من 
٠‏ وذلك بافتراض أن أطول اسم مؤلف لن يزيد عن ٠١‏ حرفا. 

اضغط بالفأرة على الحقل «00112/11©» وفي المنطقة السفلى من النافذة 
غيّر قيمة الخاصيّة "حجم الحقل" 5126 ل[ع۴1 إلى م)ر8.. السبب في هذا 
أننا لن نتعامل إلا مع ١١‏ دولة عربية فقط.. وحتى لو أضفت بعض البلاد 
الأجنبية» فإن الوحدة الثنائية 83:6 تقبل أرقاما من ٠‏ إلى ٠٠١‏ وهو ما 
يستوعب أهم أسماء دول العالم.. لاحظ أن اختيار حجم أقل للحقل يوفر 


۲۸ 





























مساحة قاعدة البيانات» ويجعل التعامل معها أكفأ.. لكن 00 أن تراعي أي 
ملموسا في قواعد البيانات الضخمة؛ وهر ما قد يؤدي إلى تعطيل الموظفين 


الذين يتعاملون مع قاعدة البيانات في ذلك الوقت.. لهذا ينصح بإجراء 
التعديلات على تركيب قاعدة البيانات في الأوقات التي 0 في مسحل 
الج قو واا سنا 


- اضغط بالفأرة على الحقل مم50 » وفي المنطقة السفلى من النافذة غيّر 

قيمة الخاصية "حجم الحقل" ع1؟ 21611 إلى ..٠0١‏ أعرف أنك تتساءل 
واس e E‏ ته سات 

ا المميزة فيه» مثل 

+2 -75 

+2 - 050 - 17354-6 

هذا يجعله أكثر وضوحا عند قراءته.. لكن البعض يرد على هذه 

النقطة قائلا إن من الممكن حفظ رقم الهاتف في قاعدة البيانات 

كرقم» وعند عرضه في نموذج فيجيوال بيزيك يمكن تنسقيه بأي 

شكل مطلوب. . من وجهة نظري أن هذا قد يسبب بعض المشاكل» 
بسبب اختلاف تركيب رقم الهاتف من دولة إلى أخرى. 

3 نظرا لوجود مفتاح لكل دولة. ومفتاح لكل منطقة. فإن رقم الهاتف 
سيكون عددا كبيرا جداء ولن يكفيه العدد الصحيح الطويل 
16561 1.025 (وهو يستخدم وعtرB‏ 4)» وهو ما يتطلب استخدام 
نوع بيانات كبير» وفي هذه الحالة لن يكون هناك توفير كبير عن 
استخدام النص! 

۳- أهم نقطة في الأمرء هو أن تطبيق آكسيس يحذف الأصفار المكتوبة 
على يسار أي رقم» لهذا لو كتبت 0020102020375 فسيحولها 
إلى 20102020375» وهو ما سيجعل من الصعب عليه معرفة 
مفتاح الدولة! 

-٤‏ إذا أردنا حل مشاكل استخدام الأرقام» فلا بد من حفظ مفتاح كل دولة 
بمفرده في عمود خاص به. . في هذه الحالة يجب وضعه في جدول 
الد مع مفتاح كل منظفة زا المحافظة):. عن ها قد يح 
الأمور أعقد برمجيا ويضيع وقتا دون أن يوفر مساحة تذكر. 

الآن اضغط [+S‏ لحفظ الجدول.. سيظهر لك مربّع إدخال يطالبك بإدخال اسم 
الجدول.. سمه وام طاں۸ واضغط زر )0. 
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الآن لو أغلقت نافذة التصميمء فستجد الجدول 411015 قد أضيف إلى نافذة قاعدة 
البيانات.. انقره مرتين بالفأرة.. سيؤدي هذا إلى فتح نافذة جديدة تعرض لك جدول 
المؤلفين في وضع التحريرء حيث يمكنك إدخال بيانات كل مؤلف» مع ملاحظة أن 
حقل الترقيم التلقائي (11 لا يسمح لك بالكتابةء فقيمته تزيد تلقائيا كلما أدخلت سجلا 
جديدا. 


ملاحظات حول تحرير الجداول: 

- ضغط رأس العمود بالفأرة» يحدد العمود كله. 

- ضغط رأس الصف بالفأرة» يحدد الصف كله. 

- يمكن الانتقال من خانة إلى أخرى بضغط الزرٌ م18. 

- لإدخال سجل جديد اكتب في السجل الفارغ في نهاية الجدول. 

- عند تغيير قيمة أي خانة» لا يتم حفظ التغييرات إلا عند الخروج من الصف الذي 
توجد فيه إلى صف آخرء أو عند ضغط زر الحفظ.. فإذا وجد آكسيس أن 
إحدى القيم غير مقبولة» عاد إلى نفس الصف وأعلن رفضه للتغييرات التي 
قمت بهاء ولا يسمح لك بمغادرة الصف قبل تصحيح القيمة الخاطئة. 

- لحذف أي صف» حدّده واضغط الزر 126166 من لوحة المفاتيح» أو اضغط أمر 
Delete‏ من القائمة الموضعية .Context Menu‏ 





وبنفس الطريقة يمكنك تصمّم باقي الجداول.. ستجد هذه الجداول في قاعدة البيانات 
م.8001 المرفقة بأمثلة هذا الكتاب» وستجد فيها الجداول التالية: 


75م أاجدول المؤلفين. 

55 اجدول الكتب.. لاحظ أننا سنحفظ في هذا الجدول رقم الناشر ورقم 
الو لت وغدد الس الكلية الاك من كل كات وس اة 
وتاريخ طباعة الكتاب» ورقم الطبعة. 

عم اجدول أصناف الكتب» وهو مرتبط بجدول الكتب. 

195 اأاأسماء الدول» وهو مستخدم مع جدولي المؤلفين والناشرين. 

75 | جدول الناشرين. 

65 إجدول مبيعات الكتب» وهو يحتوي على فواتير بيع الكتب» حيث 
سنسجل عدد النسخ المبيعة من كل كتاب» والخصم الممنوح 
للمشتري» واسم المشتريء وتاريخ البيع. 








إنشاء علاقات بين الجدا 


دعنا الآن نربط حقلي رقم المؤلف بين جدولي المؤلفين والكتب» لتحقيق التكامل 
المرجعي 1016812110 116161604121 بين الجدولين: 
































من قائمة الأدوات 10015 اضغط الأمر "علاقات" ومتطوم126130.. ستظهر لك 
نافذة "إظهار جدول" وفيها أسماء كل جداول قاعدة البيانات.. اختر الجدول الذي 
تريد استخدامه في العلاقة واضغط زر الإضافة 400 »: وكرر هذا مع كل الجداول 
المطلوبة.. بعد أن تنتهى أغلق هذه النافذة» لتظهر لك نافذة العلاقات» وفيها ستجد 
كل جدول في صورة مستطيل عليه عنوان الجدول» وبه أسماء أعمدته. 

ولإنشاء علاقة بين الجدولين» اسحب الحقل (]1 بالفأرة من جدول المؤلفين» وتحرّك 
بالفأرة إلى الحقل (41140111 في جدول الكتب.. ستلاحظ تغيّر شكل مؤشّر 
الفأرة.. اترك زر الفأرة الأيسر فوق هذا الحقل.. هنا ستظهر لك نافذة إنشاء العلاقة 
بين الحقلين: 


اعالق 


جتدول /استعلام! جتدول /إاستعلام مرتيظ؛! 









Books > Authors 


٠‏ آ فرض التكامل المرجعي 
آانتالي تحديث الحقول المرقطة 


١‏ نتالي حذف السخلات المرتبطة 


نوع العلاقة: 0 علاقة رأس بأطراف 





اضغط الاختيار "فرض التكامل المرجعي" «Enforce Referential Integrity‏ 
لتقوم قاعدة البيانات آليّا بالتحقق من صحة البيانات بين الجدولين.. وفي هذا الصدد 
لديك اختياران: 
- تتالي تحديث الحقول المرتبطة- Cascade Update Related‏ 
:Fields‏ 
فمثلاء لو غيّرت رقم المؤلف (توفيق الحكيم) من ١‏ إلى ١٠ء‏ فسيتمٌ تغيير 
رقم المؤلف (4110111 تلقائيًا ليصير .٠١‏ في سجلات كل الكتب التي 
ألفها. 


٤١ 














ملحوظة: 

لن تستطيع تغيير قيمة رقم المؤلف (11 في جدول المؤلفين» لأنه ترقيم 
تلقائي.. ولو أردت تغييره؛ فعليك بتغيير نوع الحقل من ترقيم تلقائي إلى 
رقم» على أن يكون هذا قبل إنشاء العلاقة» فمن غير المسموح تغيير نوع 
بيانات حقل داخل في علاقة.. فإذا كنت قد أنشأت العلاقة فعلاء فعليك 
حذفها أولا ثم تغيير نوع الحقلء ثم إعادة إنشاء العلاقة مجددا! 

:Cascade Delete Related Fields تتالي حذف الحقول المرتبطة‎ - 


فمثلاء لو حذفت سجل المؤلف (نبيل فاروق) من جدول المؤلفين» فسيتة 
حذف كل كتب (نبيل فاروق) تلقائيًا من جدول الكتب. 








اضغط الزن "إنشاء" م)وع) لإغلاق هذه النافذة.. الآن سيظهر خط يربط 
الجدولين.. ولو أردت حذف أي علاقة؛ فاضغط الخط الخاص بها بزرٌ الفأرة 
الأيمن» ومن القائمة الموضعيّة اختر "حذف" م1ه1ع10. 

بمثل هذه الطريقة يمكنلك إنشاء العللاقات بين جداول قاعدة بيانات الكتب» كماهو 





موضح في ا 
كينا E‏ [علاقات ] - a Microsoft Access‏ 
× م - > ملف تحرير عرض علاقات أدوات إطار ا 


ب (ها |-هة 8 | »< | :88 BEF‏ ن | به 3 | 5 1 2 ذا 





زد 
Auther‏ 
CountryID‏ 
Phone‏ 
About‏ 











DP 
Publisher 
CountryID 
Phone 
Address 


| mi E 
رم حاهز‎ 


DPD 
Class 








وكما ترى» تقدم لك نافذة العلاقات مخططا بيانيا يلخص كل تفاصيل قاعدة البيانات 
والعلاقات التي تربط بين جداولهاء ممايسهل عليك مراجعة تصميمها في أي 
لحظة» كما يمكنك طباعة هذا المخطط باستخدام الأمر "طباعة العلاقات" ما" 


٤ 











95 من القائمة 1116» حيث سيؤدي هذا إلى عرض نافذة جديدة بها مخطط 
العلاقات فى شكل صبفحة قابلة للطباعة: 





5ه العلاقات ل] - عوععع8 غ؟مدوهوعءع511 كم 


3 ” - 8 ملف تحير هرض لذوات إطار ‏ تعليمات 1 


_ 3 -ت © - "ل إعداد الاق - احنواء 8 هه زه حر اك - هذ 





جاهر 


في هذه النافذة يمكنك استخدام الأمر "إعدادات الطباعة" وم؟ 1:4 و "طباعة" 
Pint‏ من القائمة »17116 لطباعة الصفحة المعروضة. 


قم بحفظ التغييرات» وأغلق نافذة العلاقات.. افتح الآن جدول المؤلفين.. ستلاحظ 
ظهور العلامة "+" بجوار كل حقل.. اضغط أيا منهاء ولتكن المجاورة ل (توفيق 
الحكيم).. ستجد أنّ العلامة "+" تحوّلت إلى العلامة "-"؛ وأنّ جدولا صغيرا 
يحتوي على الكتب التي ألفها توفيق الحكيم قد ظهر.. ولإخفائه ثانية أعد ضغط 
العلامة "-" 


AF 
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السجل:| 1« | * 5 || 4 |41 م 3 


ويمكنك إدخال المزيد من كتب (توفيق الحكيم) في هذا الجدول الفرعي»؛ دون أن 
تدخل رقمه في الخانة (411]0111 في كل مرة» إذ ستتم كتابة هذا الرقم آليّاء مما 
يوفر عليك الوقت ويعفيك من احتمالات الخطأ. 


إنشاء قيد 025612124'): 

افترض أنك لسبب ما تريد أن تمنع مُدخل البيانات من كتابة مؤلف اسمه (موهوب) 
في حقل أسماء المؤلفين.. لفعل هذا افتح تصميم جدول المؤلفين» وحدد الحقل 
6ااں.. ستجد ضمن الخصائص الموجودة في المنطقة السفليّة من النافذة 
خاصيّة تسمى "قاعدة التحقق من الصحكة" 002502101) عاءععط0).. هذا هو المكان 
الذي سنظلم فيه المؤلف العبقري (موهوب) ونحرمه من حقه المشروع في الظهور 
في قائمة المؤلفين!! 

اكتب في هذه الخانة ما يلي: 





"مو هوب" <> 
اضغط زر الحفظ.. ستظهر لك رسالة تستوثق من ر غبتك فى أداء هذه القاعدة» 
التي ربّما تستهلك بعض الوقت نتيجة فحص أسماء المؤلفين أولا للتأكد من أنها 
تخضع لهذا القيد.. اضغط )0. 
افتح تخطيط الجدول» وحاول أن تكتب الاسم (موهوب) في حقل المؤلفين.. تذكر 
أن التغيير لن يحدث قبل أن تغادر الصف الذي تكتب فيه.. وفور أن تفعل هذاء 
ستظهر لك رسالة تخبرك أن إحدى القيم المدخلة غير مسموح بهاء وسيعود المؤثئر 
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إلى تلك الخانة مرة أخرى!.. غيّر هذا الاسم» فمهما حاولت لن تستطيع إقناع قاعدة 
البيانات بقبوله. 

هذه الإمكانية مفيدة» وتمكنك من وضع شروط معقدة تدخل فيها بعض دوال 
فيجيوال بيزيك المسموح باستخدامها في جمل ,501.. ويمكنك أن تضغط الزر 
المنحاون لخاد التحكق من الحكة لتظير لك ذف تساهدك: فى اء الشوظ: حت 
تعرض لك كل الدوال والتعبيرات المسموح باستخدامها. 1 


ضغط قاعدة البيانات :Database Compacting‏ 

عندما تحذف أحد السجلات من أحد الجداول» فإنه يختفى من عرض الجدول» ولكنه 
في الواقع يظل في موضعه في ملف قاعدة البيانات.. كل ما حدث هو أنّ قاعدة 
البيانات قد أشارت إلى حالته باعتباره سجّلا محذوفاء حتى لا يتمٌ التعامل معه.. ولو 
حدث في برنامجك أن أصبح السجل الذي تتعامل معه محذوفا (بسبب قيام مستخدم 
آخر لقاعدة البيانات بحذفه)؛ فإِنٌ محاولة قراءة البيانات أو كتابتها في هذا السجل 
ستؤدي إلى حدوث خطإ في برنامجك. 

وقد تظن أنّ هدف إخفاء السجل المحذوف هو منحك القدرة على التراجع عن 
حذفه.. ولكن هذا ليس صحيحا على الإطلاق» فالسجل الذي يحذف لا يمكن 
استعادته» رغم أنه ما زال موجودا في ملف قاعدة البيانات موسوما بأنه محذوف! 
لماذا إذن تستخدم قاعدة البيانات هذه الطريقة؟ 

تخيّل أنك تريد حذف سجل موجود فى منتصف ملف قاعدة البيانات.. كيف فى 
نظرك يحدث هذا؟ ١‏ 1 
لحذف هذا السجل يجب أن ينشئ تطبيق قاعدة البيانات ملفا احتياطيّاء وينسخ إليه 
البيانات السابقة للسجل المراد حذفه» ثم البيانات التالية له» وبهذا يتكوّن ملف جديد 
لا يحتوي على السجل المحذوف.. بعد هذا يجب أن يحذف التطبيق ملف قاعدة 
البيانات القديم» ثمّ يسمّى الملفّ الجديد باسم قاعدة البيانات.. واضح أنّ هذه الطريقة 
ستؤدي إلى بطء عمليّة الحذف» بسبب الاضطرار إلى نسخ كل محتويات ملف 
قاعدة البيانات لمجرد حذف سجل واحد.. تخيل حجم الكارثة التي ستحدث لو 
حاولت حذف ألف سجل على التوالى بهذه الطريقة! 

لهذا كان الحل هو أن يتم ترك السجل المحذوف في موضعه»ء على أن تتمّ الإشارة 
إلي حالته باعتباره سجلا محذوفا. 

ولكنّ معنى هذا أنّ حجم قاعدة البيانات يمكن أن يتضخم باستمرار مع استمرار 
العمل عليها والإضافة إليهاء لأنَ كل ما يحذف منها يظل في موضعه.. لدرجة أنك 
لو حذفت كل السجلات من كل الجداول» فسيظل لقاعدة البيانات نفس حجمها!! 
ولحل هذه المشكلة» يجب أن تقوم بين فترة وأخرى بعملية تسمى "ضغط قاعدة 
البيانات" Database Compan‏ وفيها يتم إنشاء نسخة جديدة من ملف قاعدة 
البيانات لا تحتوي على السجلات المحذوفة. 


{° 


وللقيام بهذا في ووعءء۸» اضغط قائمة الأدوات 10015: ومنها اضغط القائمة 
الفرعية "آذوات مساعدة لقواعد الائات" ومتها اضغط الأمر "خط قاعدة بياناك 
وإصلاحها" ..€0mpact and repair database‏ هنا سيقوم ووئعن340 بإغلاق 
قاعدة البيانات وضغطها ثم إعادة فتحها.. ولو اختبرت حجم ملف قاعدة البيانات» 
فربّما تجده أقل مما كان عليه. 

عا عا عاو 
بهذه النبذة السريعة» نكون قد أنهينا حديثنا عن ووعءء۸.. وطبعا ليست هذه هي كل 
إمكانيّات هذا التطبيق الشهير» فهو قادر في حد ذاته على إنشاء النماذج والتقاريرء 
وكتابة كود لغة خاصة من فيجيوال بيزيك تسمّى Visual Basic For‏ 
5 أو اختصارا ۰۷8۸ وهو ما يخرج عن نطاق هذا الكتاب.. إن 
و5 له وحده مراجع متخصصة! 
والآن» دعنا نتعرف على كيفية الاتصال بقاعدة بيانات ووعععكر في دوت نت. 


تصفح الخوادم :Server Explorer‏ 
توجد في فيجيوال ستديو نافذة اسمها متصفح الخوادم 1ع101م:1 »Se۷e۲‏ وهي 
تحوي كل الأدوات الأساسيّة اللازمة للاتصال بقاعدة البيانات والتعامل معها.. 
ويمكنك عرض هذه النافذة بضغط الأمر 1ع101م:8 إمرإمS‏ من القائمة 97ع1/آ.. 

وعندما تظهر لك نافذة متصفح الخوادم» ستجد فيها عنصرين: 


روابط البيانات Server Explorer ha :Data Connections‏ 
تحت هذا العنصرء تظهر أسماء قواعد البيانات 4اك ك 

التي تتعامل معها في تطبيقاتك المختلفة.. وسنرى Data Connections‏ 
كيف يمكن الاتصال بقواعد البيانات لاحقا. SEerVEerS‏ # ...م 


الخوادم و-رعزءع5: 

تحت هذا العنصر› > تظهر أسماء خوادم قواعد 
البيانات Serves‏ ع1238035 التي تتعامل با وما تمنحه لك من كائنات.. 
وستجد مبدئيا اسم جهاز الحاسب الخاص بك موجودا تحت هذا الفرع» وذلك لأنه 
يعمل كخادم محلي 56151 1.0031 لتتمكن من خلاله من التعامل مع قواعد 
البيانات الموجودة على جهازك. 

الاتصال يقواعد يبانات 4©©6©559: 


اضغط بزر الفأرة الأيمن العنصر 01226011055© وه( في متصفح الخوادم؛ 
ومن القائمة الموضعية اضغط الأمر "إضافة اتصال" ..Add e‏ 








كك 


سيظهر لك مربّع حوار "اختيار مصدر البيانات" source‏ 03148 00056» وفيه 
قائمة تحتوي على أسماء العديد من برامج قواعد البيانات: 


»اا 501 0313 عوشقطا6 


Data source: 
; Description 


Microsoft Access Database File 


Use this selection to connect to a 
Microsoft Access database file 
Microsoft SQL Server Compact 3.5 through the .NET Framework Data 
Microsoft SQL Server Database File Provider for OLE DB. 

Oracle Database 
<other> 







Data provider: 


[NET Framework Data Provider for C -| 
١ Always use this selection Cancel 
2 








اختر من القائمة العنصر: Access Database File‏ tiگMicroso..‏ لاحظ وجود 
قائمة منسدلة أسفل النافذة تتيح لك اختيار مزود البيانات Data Provider‏ الذي 
ستستخدمه في برنامجك للاتصال بقاعدة البيانات.. بالنسبة لقواعد بيانات ووععع/م 
لن تحتوي القائمة المنسدلة إلا على المزود الخاص بقواعد بيانات 58 0117: 

.Net Framework Data Provider for OLE DB 
للانتقال إلى النافذة التالية, وهي نافذة "إضافة‎ Continue بعد هذا اض خط الزر‎ 
:Add Connection اتصال"‎ 


5 








Add Connection 77 9 


Entar information to connect to the selected data source or 
click "Change" to choose a different data source and/or 
provider, 


Data source: 


Microsoft Access Database File (OLE DB) Change... | 
Database file name: 
F: __Batabase_VEB\Samples\Eooks.mdb Browse... 
Log on to the database 
User name: Admin 
Password: | 
T Save my password 


ka 


Test Connection OK Cancel 





ستجد اسم مزود البيانات في الخانة العلوية في النافذة. . لو أردت تغيير هذا المزود» 
فيمكنك الضغط على الزر ع138© للرجوع إلى النافذة السابقة واختيار مزود 
لنوع قاعدة بيانات من نوع آخر. 

الآن عليك اختيار ملف قاعدة البيانات» وذلك بكتابة مسار واسم الملف مباشرة في 
الخانة Database 1116 Nae‏ أو ضغط الزرٌ 220186 لاختيار ملف قاعدة 
البيانات من على القرص الصلب.. اختر الملف 80015.10 من الموضع الذي 
حفظته فيه على جهازك (ستجد هذا الملف على القرص الضوئي المرفق 
بهذا الكتاب). 

ويقيع لك الضيقك اللي سن الثافذه اال اسم الستقدم و كلها انر القاضة 
بقاعدة البيانات.. لكن نظرا لأننا لم نضع كلمة سر لقاعدة بيانات الكتب» فاترك 
هاتين الخانتين بدون تغيير: اسم المستخدم الافتراضيّ «نصل۸» وكلمة السر 
ويمكنك ضغط الزر 000216601101 54و16 لاختبار الاتصال بقاعدة البيانات.. 
ستظهر لك رسالة تؤكد نجاح الاتصال.. أما لو فشل الاتصال لسبب ماء فستظهر 
وسالة خطا تخيرك أن هناك مشكلة: 


۸ 


اضغط الزر 0 لإغلاق مربّع الحوار.. Server Explorer SaaS‏ 





و عا اف اه 1 بذ | لا لعا 
سيظهر اسم قاعدة البيانات الص.B00)s‏ في | إ8 د > 
متصفح الخوادم» كما هو موضح في الصورة EBooks mdb‏ ل 
المجاورة. û. Ba Tables‏ 

a ل‎ Authors 
AID 1 اضغط العلامة "+" بجوار اسم قاعدة البيانات..‎ 

0 : مسي ال Auther 5 Sl‏ 3 
00 داب اد الي اتكون يديا جامد CountryID‏ 3 

ا Phone‏ 3 
أوؤل عنصر من هذه العناصر هو الجداول About‏ 3 
و6 :» ولو أسدلت ما تحتها من عناصر› 3 ...م 
فستجد أسماء الجداول التى أنشأناها فى قاعدة Classes‏ ١م‏ 
السانات A Countries‏ .م 
Publishers OTT 1 ET‏ ل a.‏ 
ولو أسدلت عناصر أي جدول» فستجد تحته :0 





ا 





3 Sales 
0 أسماء الأعمدة التي يحتويها. ل‎ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النار» وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكانء واهزم أعداءنا وخلصنا من عملائهم 
آمين يا رب العالمين 


۹ 


۴ 


قواعد بيانات 56157761 SQ‏ 


كانت إصدارات فيجيوال ستديو السابقة لدوت نت» تدعم استخدام قواعد بيانات 
9م باعتبارها أهم قاعدة بيانات أصدرتها ميكروسوفت.. لكن مع ظهور دوت 
نت» احتلت قواعد بيانات 56201 ,501 هذه المكانةء نظرا لأنها الأنسب للتعامل 
مع قواعد البيانات العملاقة التي يتصل بها آلاف المستخدمين في نفس اللحظة عبر 
شبكة داخلية kإم‏ سم" أو عبر الشبكة الدولية ٤عصإه†م]..‏ لعل هذا يوضح لك 
سبب وجود المصطلح "5٥۲۷٥۲"‏ في اسمهاء فقواعد بيانات سيكويل سيرفر يجب 
أن تعمل على خادم محلي [0٥۵1 S۷٥۲‏ أو خادم موجود ر الشبكة عnمOnli‏ 
1 ليقوم بتنظيم عمليات الاتصال بها وطلب البيانات منها.. ولو تم فصل 
قاعدة البيانات من هذا الخادم 0ع10150022601»: لا يمكن NF‏ إلا بعد إعادة 
توصيلها بالخادم مجددا 0ع0021601).. إذن فنحن نتعامل هنا مع خادم البيانات» 
ولا نتعامل مع ملف البيانات مباشرة كما كنا نفعل في قواعد بيانات آكسيس. 
وهناك ثلاثة إصدارات شهيرة من سكيول سيرفر حتى الآن: 
:SQL Server 2000 -١‏ 
وهو متكامل مع دوت نت ۲۰۰۲ ودوت نت ۰۲۰۰۳۲ ولاستخدامه يجب 
أن تعد على جهازك أولا برنامجا اسمه: 
Microsoft SQL Server Desktop Engine‏ 
أو اختصارا »)MS5٤(‏ والذي ستجده على أسطوانة 
Microsoft Office XP‏ في المجلد .MSDE2000‏ 
:SQL Server 2005‏ 
وهو متكامل مع دوت نت ٠٠٠١5‏ ودوت نت ۰۲۰۰۸ ولاستخدامه يجب 
أن تعد على جهازك أولا برنامجا اسمه: 
SQL Server Management Studio Express‏ 
وهو نسخة مجانية خفيفة من 2005 501561561 تمتلك قدرات أقل من 
اللسبكة الكاملة: كنيب كافية للقاية لأنشماء قو عة بوافات كسكنة يضيل 
حجمها إلى ٤‏ جيجا بايت» ويمكنها أن تتصل بأكثر من ؟" ألف قاعدة 
بيانات» والاستجابة لاتصال بضع مئات من المستخدمين في نفس اللحظة.. 
ويمكنك الحصول على نسخة من هذا البرنامج هن.صفحة تنزيل البرامج 
من موقع ميكروسوفت: 


لا 
چ 


http://www.microsoft.com/downloads 
في أعلى هذه الصفحة ستجد مربع البحث.. اكتب فيه النص:‎ 
SQL Server Management Studio 
واضغط زر البحث (الذي تمثله أيقونة العدسة ).. ستجد في نتائج‎ 
التشغيل الموجود رها‎ ey واضغط زر تنزيل‎ 


:SQL Server 2008 ="‏ 
وهو متكامل مع دوت نت ٠۲٠٠١‏ ولاستخدامه يجب أن تعد على جهازك 
SQL Server 2008 Management Studio Express‏ 

ميكروسوفت بطريقة مماثلة للتي شرحنها سابقا. 


إعداد :Management Studio Express‏ 
قبل أن تبدأ إعداد هذا البرنامج على جهازك» علي أن أنبهك إلى ضرورة التأكد من 
أنك قد اخترت إعداد العنصر: 
Microsoft SQL Server 2008 Express Edition‏ 
أتكباء [غنداد فيجيؤال سثديو دوف يت >٠ ١‏ وال شان عليك إعبادة تشغيل ملف 
إعداد دوت نتء واختيار Add or Remove Features‏ ومن ثم وضع علامة 
الاختيار أمام هذا العنصرء حتى تستطيع فيجوال ستديو التعامل مع سيكويل سيرفر 
۸ أيضاء يحتاج برنامج الإعداد وجود البرامج التالية على جهازك: 
Windows Installer 4.5‏ 
WS-Management v1.1‏ 
Windows PowerShell V2 (CTP3)‏ 
.NET Framework 3.5 SP1‏ 
ويمكنك الحصول عليها من صفحة تنزيل البرامج من موقع ميكروسوفت كما 
شتريحتا أغللاه. 
والآن» اضغط برنامج الإعداد الخاص اله 
SQL Server 2008 Management Studio Express‏ 
وانتظر حتى تظهر الشاشة الموضحة في الصورة: 





كتملع 3 جه عابطنا ولاه عجارا + بوك 5020 2ه 
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SQL Server 2008 


من الهامش الأيسرء اضغط الاختيار الثاني 11ه†وم][ء حيث سيعرض لك الجزء 
الأيمن من النافذة عدة اختيارات.. إذا لم تكن قد أعددت إصدارا سابقا من سيكويل 
سيرفر على جهازك» فاضغط الاختيار الأول.. سيتم أولا التأكد من وجود 
المتطلبات اللازمة للإعداد على جهازك.. فان كانت كلها موجودة» فاضغط 0K‏ 
وواصل باقي خيارات الإعداد.. وتأكد دائما من ضغط الزر ۸11 5616014 في كل 
صفحة تعرض العناصر المتاحة للإعداد. لتضمن إعداد كافة مكونات البرنامج. 
بعد انتهاء عملية الإعداد» توجه إلى سطح المكتب Desktop‏ واضغط: 

Start\Programs\Microsoft SQL Server 200815001 Server Management Studio 
سيؤدي هذا إلى فتح مدير قواعد بيانات سيكويل سيرفر SM8؟S؟» وأول ما‎ 
سيعرضه لك هو نافذة الاتصال بخادم قاعدة البيانات:‎ 


EESTI > 


Microsoft® 
حر‎ SQL Server 2008 
Server type: [Database engine ع‎ 


Server name: YSERYERISQLEXPRESS 
Authentication: [windows Authentication S| 
User name: eemhmd >] 
Password: چ چ ھھھ ”کڪ‎ 


FT Remeber password 








Cancel | Help | Options << | 





o1 





هذه النافدة تنيح لك تحديد ثلاث خيارات: 


:Server Type نوع محرك خادم البيانات‎ -١ 
تعرض لك هذه القائمة المنسدلة نوعين من الخوادم:‎ 
وهو النوع الذي سنستخدمه في برامج‎ :Database Engine أ-‎ 
.4572.7/171' الويندوز وصفحات المواقع‎ 
وهو النوع المستخدم مع‎ :501 Server Compact Edition ب-‎ 
الأجهزة الكفية المحمولة.‎ 
:Server Name ؟- اسم الخادم‎ 


يمكنك كتابة اسم خادم ت 0 


Locsl Servers | Network Servers | 


Salect the semer ba coanect tal في هذه القائمة مباشرة» أو‎ 


الخادم» حيث ستعرض لك Databases‏ مااع Server Cores‏ 3 ا 
القائمة المنسدلة أسماء الخوادم 
التي اخترتها سابقاء بالإضافة 
إلى العنصر <Browse for‏ 
<...018» ولو ضغطت هذا 
العتضير فستطير لتك اة 
اختيار الخادم» وهي تعرض 
شريطين علويين و18 22 | | | »1 

أولهما يتيح لك اختيار خادم ٠‏ 

محلي (موجود على جهازك)» والآخر يتيح لك اختيار خادم موجود على 
الشبكة ع716:011.. وسنستخدم في هذا الكتاب خادما محليا ]هعم 
ع1 ولو ضغطت العلامة + الموجودة بجوار «Database Engine‏ 
فستجد تحتها أسماء الخوادم المحلية الموجودة على جهازك.. وعلى الأقل 
ستجد خادما واحداء هو خادم سيكويل سيرفرء حيث يتكون اسم هذا الخادم 
من اسم جهازك وليكن ٣۲رMy)‏ يليه اسم خادم سيكويل سيرفر 
65 ااختر هذا الخادم واضغط 0 للعودة إلى النافذة 
الأولى.. ستجد في مربع النص اسم الخادم ..MYPC\SQLEXPRESS‏ 
لاحظ مجددا أننا سنستخدم في هذا الكتاب الاسم 77:20 باعتباره اسم 
الجهاز.. لكن لو كان اسم جهازك مثلا 710113101112070 فستجد في هذه 
الخانة الاسم: ...MohammadPC\SQLEXPRESS‏ وهكذا. 








۳- تحقيق الهوية :Authentication‏ 
تتيح لك هذه القائمة المنسدلة نوعين من تحقيق الهوية: 


أت 


ده 


تحقيق الهوية بواسطة الويندوز :Windows Authentication‏ 
في هذا النوع لا يتم حماية الاتصال بالخادم باسم مستخدم وكلمة 
سر خاصة بل تكون الحماية معتمدة على بيانات مستخدم 
الويندوز.. بمعنى أن مستخدم الويندوز الذي أنشأ الاتصال 
يستطيع الاتصال بالخادم والتعامل مع قواعد البيانات المتاحة 
بمجرد تسجيل دخوله على الويندوز.. وهذا هو نوع تحقيق الهوية 
تحقيق هوية خادم سيكويل :SQL Server Authentication‏ 

في هذا النوع تتم حماية الاتصال بالخادم وكل قواعد البيانات 
التي ستنشئها عليه باسم مستخدم ©1796111811] وكلمة مرور 
00 -+؛ حيث يتم تفعيل مربعي النص الخاصين باسم 
الموجودة على الشبكة لأنها تكون محمية ضد محاولات 
خادم البيانات كما يحددها مدير النظام.. فهناك مستخدمون 
يستطيعون إضافة أو حذف قواعد البيانات أو الجداول والأعمدة 
والشكلاة: يرتم تفتخير :شيا هيات يعكن المستخدمين على 
قراءة البيانات من بعض الجداول.. لهذا في الغالب لا تسمح 
الخوادم الحقيقية (غير الخادم المحلي الافتراضي) بالاتصال بها 
بدون أن يحدد المتصل اسمه وكلمة مروره. 


بعد أن تنتهى من إدخال هذه البيانات» اضغط 0O‏ لإغلاق النافذة وإنشاء 
الاتصال.. سيؤدي هذا إلى إضافة اسم الخادم الذي اتصلت به إلى متصفح الكائنات 
1 ]إن ز0 الموجود على يسار نافذة مدير سيكويل سيرفرء ولو أسدلت 
العناصر الفرعية لهذا الاتصال» فستجد من ضمنها العنصر 1(031802565» وهو 
العنصر الذي تظهر تحته كل قواعد البيانات التي تعمل على هذا الخادم» كما يمكنك 
من خلال هذا العنصر إضافة قواعد بيانات جديدة إلى الخادم» أو تشغيل قواعد 
بيانات موجودة مسبقا. 


o 


في متصفح الكائنات 12ع101م15 6ع06[6: اضغط فرع قواعد البيانات 
65 بزر الفأرة الأيمن» ومن القائمة الموضعية Meu‏ :ع001) اضغط 
الأمر 103680256 7137 لعرض نافذة إنشاء قاعدة بيانات جديدة. 
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Serves 1 
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بوساح م11 
occas‏ ستاعموودس جونذ 37 


اذ ET n‏ 
لشفي ااال الل ار 


هذه النافذة تتيح لك إنشاء أكثر من قاعدة بيانات» حيث تحتوي على جدول يعرض 
تفاصيل ملفات قواعد البيانات التي تريد إنشاءها.. كل ما عليك هو كتابة اسم قاعدة 
البيانات في الخانة Database Name‏ أعلى النافذة» حيث ستلاحظ ظهور ملفين 
في الجدول السفلي يحملان اسم هذه القاعدة.. فمثلاء لو كتبت الاسم Books‏ في 
خانة اسم قاعدة البيانات» فسيعرض الجدول الملفين الآتيين: 
:Books.mdf -١‏ 
هذا هو الملف الذي يحفظ بيانات قاعدة البيانات» وستجد أن خانة النوع 
المجاورة لاسمه تشير إلى أنه Rows Data‏ أي أنه يحمل بيانات 
السجلات.. وستجد أن خانة الحجم المبدئي تشير إلى أن حجم هذا الملف 
سيكون مبدئيا ۲ ميجاء وسيزيد بمعدل ١‏ ميجا في كل مرة تتجاوز فيها 
البيانات حجم الملف.. ويمكنك أن تغير الحجم المبدئي ومعدل الزيادة تبعا 
لنوع قاعدة البيانات التي تتعامل معهاء فلو كنت تتوقع معدلا كبيرا لإضافة 


oo 


البيانات إليهاء فالأفضل أن تجعل معدل زيادة حجمها أكبر» لأن هذا يوفر 
الوقت المستهلك عند تكرار عملية تكبير الملف. 


:Books_log.ldf ڵ-‎ 


هذا هو الملف الذي يحفظ سجل أداء قاعدة البيانات ع1.0» وستجد أن خانة 

النوع المجاورة لاسمه تشير إلى أنه عم].. وستجد أن خانة الحجم المبدئي 

تشير إلى أن حجم هذا الملف سيكون مبدئيا ١‏ ميجاء وسيزيد بمعدل 9٠١‏ 

من حجمه في كل مرة تتجاوز فيها البيانات حجم الملف.. ويمكنك أن تغير 

الحجم المبدئي ومعدل الزيادة تبعا لحاجتك. 

لاحظ أن ملف سجل الأداء ع0ا يخزن كل التفاصيل التي تتم على قاعدة 

البيانات من إضافة وحذف واستعلامات وغيرهاء ومن قام بها ومتى» وهذا 

يجعل حجمه يتضخم بسرعة كبيرة» لأنه سيحتوي على البيانات الأصلية 

وكل التعديلات التي تمت عليها.. هذا يحقق الفوائد الاتية: 

-١‏ يقدم تاريخا مفصلا للعمليات التي تمت على قاعدة البيانات» ويسهل 
مراقبة أدائها ومعرفة حجم نشاط المستخدمين المتعاملين معها. 

؟- يتيح لك استعادة أي وضع سابق لقاعدة البيانات» ليمكنك التراجع عن 
أية عملية غير مرغوبة لاستعادة حالة قاعدة البيانات قبل إجرائها. 

3 يحمي البيانات من الضياع. . ففي قاعدة بيانات ووعع8480 يمكن أن 
يؤدي انقطاع الكهرباء أو حدوث أي مشكلة في الويندوز أثناء حفظ 
بعض البيانات إلى تدمير ملف قاعدة البيانات كلهاء لأن عملية الحفظ 
تتم في الملف مباشرة.. بينما في سيكويل سيرفر يتم حفظ التغييرات 
في ملف سجل الأداء ع1,0 أولاء وبعد مدة زمنية معينة يتم نسخ كل 
التغييرات من ملف سجل الأداء إلى ملف قاعدة البيانات.. هذا يعني أنه 
لو حدثت أي مشكلة أثناء الحفظ في سجل الأداء ل ملف ليده 
البيانات سيظل سليماء وستكون البيانات المفقودة أقل ما يمكن» حيث 
سيتم فقد الجزء الذي كان يتم حفظه فقط.. ا ا 
نقل البيانات من ملف سجل الأداء إلى ملف قاعدة البيانات وأدت إلى 
تدمير ملف قاعدة البيانات» فلن تفقد أي بيانات» لأن سجل الأداء ما 
زال يحتفظ بنسخة منها. 1 


وتعرض الخانة 224 مسار حفظ كل ملف من هذين الملفين» وهو مبدئيا: 
C:\Program Files\Microsoft SQL Server\MSSQL10.SQLEXPRESS\MSSQL\DATA‏ 
ويمكنك تغيير هذا المسار بضغط زر الانتقال الموجود في هذه الخانة» لعرض 


مربع حوار اختيار مجلد. 





تنبيه: 
أنصحك بتغيير هذا المسار إلى أي مسار آخر خاص بك على جزء من القرص 
الصلب غير الذي يوجد عليه نظام الويندوزء حتى لا تفقد قواعد بياناتك في 





كه 











عملية تهيئة )1:2ه”1 طائشة؛» أو بسبب حدوث أي تدمير لنظام التشغيل لأي 
سبب كان» يجعلك تعيد إعداده دون أن تنتبه إلى أخذ نسخة من ملفاتك الهامة. 








ولإنشاء قاعدة بيانات أخرى» اضغط الزر 400 الموجود أسفل النافذة» حيث 
سيظهر صفان جديدان في الجدول.. حدد أي صف منهماء واكتب اسم قاعدة 
البيانات الجديدة فى الخانة Database Name‏ أعلى النافذة.. وإذا أردت حذف أى 
قاعذة اتات قحد أيا من ملفيهاء و اط الذى فوويوه 19 أسفل التافذة. ١‏ 
يتبقى جزء مهم في هذه النافذة» هو خانة مالك قاعدة البيانات 1عم20.. لو تركت 
قيمة هذه الخانة <1(618111> فسيكون اسم المستخدم الخاص بك على الويندوز 
Username‏ هو مالك هذه القاعدة» لكن هذا قد يحرمك بعض الصلاحيات.. لهذا لو 
أردت صلاحيات كاملةء فاضغط الزر المجاور لهذه الخانة لعرض مربع حوار 
اختيار مالك قاعدة البيانات.. اضغط الزر 220786 الموجود في النصف السفلي 
من هذه النافذة» ومن النافذة التي ستظهر اختر [sa]‏ وهو اختصار لتعبير مدير 
النظام System Administra‏ واضغط 0 لإغلاق النافذتين. 


د - 
سبال 





Enter the object nanesto select [sunrglez 








Path‏ | س لست 
„Î r:__Petebe‏ اسمن 1m, inresirtted‏ 
ەدەق |۴ | Þ 10 percerk, reiticted grûtvt‏ 









7 Obja!R ara Feurd nab hing tha نهر ممعي‎ alartad. 


EET 


Seru 
MPCISIOLDFAES 


Matching obs t51 
Nane p> 
|] 1 [2N PolkyTsEcmatinicgess] 


1 
Coeneciion | د‎ [BUN TRIRisar4] 2 
NMPCIhrad 6 1 [لمفرلعع دوم‎ 1 
937 معتهمم عه نون‎ ALAC r kË I NUTHORIIYMETAORL ERNKE] 3 
00 E MT AITHORITYOYSTEN] 1 
اه ؟ 72 كنوه"‎ EE <r 
Caasy 


بعد أن تفرغ من إنشاء كل قواعد البيانات التي تريدهاء اضغط الزر )0 لإغلاق 
النافذة وإنشاء الملفات.. غنى عن الذكر أن ضغط الزر 3261© سيلغى كل ما 
فعلته ولن يتم إنشاء أي قاعدة من التي أدخلت أسماءهاء فكل ما تدخله في هذه 
النافذة هو مجرد تفاصيل» ولا تدخل حيز التنفيذ إلا بعد ضغط الزر )0. 


oV 











الآن» ستجد اسم قاعدة البيانات 800125 تحت الفرع 10318523565 في متصفح 
الكائنات.. اضغط العلامة + المجاورة لهذا الاسم» لإسدال عناصر قاعدة البيانات.. 
ستجد ضمن هذه العناصر العنصر 1896165؛: وهو العنصر الذي يحتوي على كل 
جداول قاعدة البيانات.. اضغط هذا العنصر بزر الفأرة الأيمن» ومن القائمة 
الموضعية اضغط الأمر 13616 7117 لإنشاء جدول جديد.. سيؤدي هذا إلى 
عرض نافذة تصميم الجدول في مدير سيكويل» كما ستظهر نافذة الخصائص التي 
تعرض خصائص هذا الجدول.. الجميل في الأمر هو أن بيئة مدير سيكويل تشبه 
إلى حد بعيد بيئة التطوير المتكاملة 1177 الخاصة بدوت نت» مما سيشعرك بالألفة 
معهاء ويجعل استخدامك لها سهلا وسريعا. 

اھا 


File Edit View Debug Table Designer Tools Window Community Help 


4 New Query i حا‎ 7 ud ي نت‎ 
MYPC\SQLEXPRES...- dbo.Table_1* x 
S8 مسقت‎ Narn Data type ق سد‎ | {Tbi] dbo.Table_1 ج‎ 
e" 1 El! 
2 5 {Identity) - 
1 Authors) 
3 Database ! 
Description 
column Properties Schema dbo 
server Man mypCiSqQlex 
E?! 3 E Table Designer 
Û Nez, scecficetion Yes Identity Co ID 
i EEE ب‎ Indexable Yes 
Identity Increment 1 كد‎ 
identity Seed 1 Lock Escale Table 
=| BE Reoular Da PRIMARY |ا-‎ 
(Is Identity) (Name) 
Ready 


دعنا ننشئ جدول المؤلفين: 

أدخل أسماء الأعمدة ونوع كل منها في الجدول العلوي بنفس الطريقة التي 
استخدمناها في آكسيس» واستخدم الجزء السفلي من النافذة للتحكم في خصائص كل 
نوع.. وإذا لم تكن تريد السماح للمستخدم بترك أي خانة من خانات هذا العمود 
فارغةء فأزل علامة الاختيار من مربع الاختيار 7110115 4110177.. ولا تنس تغيير 
اسم الجدول من 13161 إلى 114015هرء ثم اضغط زر الحفظ من شريط الأدوات. 
ملحوظة: 

بعد أن تقوم بحفظ تصميم الجدول قد يرفض سيكويل سيرفر إجراء أي تعديل على 
هذا التصميم (كإضافة أو حذف أعمدة)» مع ظهور رسالة تخبرك أن التغييرات 
التي قمت بها تحتاج إلى إنشاء الجدول من جديد! 

لحل هذه المشكلة افتح Server Management Studio‏ 501», ومن القائمة 
15 اضغط الأمر 005م0» وفي نافذة الخيارات أسدل العنصر 15عمع1و126 





مه 




















من القائمة اليسرىء؛ واضغط العنصر الفرعي Table and Database Designers‏ 
كما هو موضح في الصورة: 





EF]: Environment Table Options 7 2 
EH: Text Editor ص[‎ Override connection string time-out value for table 
Hl: Query Execution designer updates: 


Hl 
Fl: Query Results 
Fl: SQL Server Object Explorer 
E1: Designers 


Transaction time-out after: 


1 30 seconds 





Table and Database Designers I Auto generate change scripts 
Fl: Source Control 
IF Warn on null primary keys 
¥ Warn about difference detection 


IV Warn about tables affected 


¥ Prevent saving changes that require table re-creation 
f Diagrarn Options 
Default table view: [column Names -| 


¥ Launch add table dialog on new diagram 








ce | 


وفي الجزء الأيمن» تأكد من إزالة علامة الاختيار من الخيار: 

Prevent Saving Changes that require table re-creation. 
0) فهذا الخيار يمنع حفظ التغييرات التي تسبب إعادة إنشاء الجدول.. اضغط‎ 
لحفظ التغييرات وإغلاق النافذة.‎ 
أما إن استمر هذا الخطأ في الحدوث في بيئة دوت نت» فاستخدم خادم سيكويل‎ 
لإجراء التعديل الذي تريده في تركيب الجدول.. فإذا أعيتك الحيلء فبإمكانك نسخ‎ 
تصميم جميع الأعمدة ولصقها في جدول جديد.. لفعل هذاء افتح نافذة تصميم‎ 
الجدول واضغط هامش العمود الأول بالفأرة» ثم اضغط الزر 51314 من لوحة‎ 
المفاتيح» واضغط هامش العمود الأخير بالفأرة» وبهذا سيتم تحديد كل الأعمدة..‎ 
اضغط 01+00 لنسخ الأعمدة» ثم أنشئ جدولا جديداء وفي نافذة التصميم اضغط‎ 
هامش العمود الفارغ بالفأرة» واضغط 01+57 للصق الأعمدة التي نسختهاء ثم‎ 
أجر عليها التعديلات التى تريدهاء أو أضف إليها أعمدة جديدة.. بعد هذا احذف‎ 
الجدول القديم» وسمّ الجدول الجديد باسم الجدول المحذوف.‎ 
لو أغلقت النافذة الآن» فسترى اسم جدول المؤلفين أسفل العنصر وع1261»‎ 
وسيكون كالتالي 150..11015» حيث إن الحروف 050 هي اختصار للتعبير‎ 
"مالك قاعدة البيانات" 001161 1(336356: وهو مستخدم افتراضي لا يمكن‎ 
حذفه.. والسبب في إضافة هذا الجدول إلى المستخدم 0560 هو أننا تركنا للخاصية‎ 
الخاصة بالجدول القيمة 050 (انظر نافذة الخصائص)» ولو غيرناها إلى‎ 3 
مثلاء فسيصير اسم الجدول 11015ا1ش. .11654 6» لأنه سينتمي إلى المستخدم‎ 011651 
وفي حالات أخرى» يضاف الجدول إلى اسم المستخدم الذي سجل دخوله‎ .. 01651 


4 
































على قاعدة البيانات» وذلك إذا لم يكن يملك صلاحيات مدير قاعدة البيانات 
.Administrator‏ 

والان» اضغط العنصر 060.11015 بزر الفأرة الأيمن.. ستعرض لك القائمة 
الموضعية مجموعة من الأوامر الهامةء منها: 


:Design 

يعرضص نافذة تصميم أعمدة الجدول. 

:Select Top 1000 rows 

يعرض أول ٠٠٠١‏ سجل في الجدول» وفي هذه الحالة لن تتمكن من تعديل 
أي شيء في هذه السجلات.. لاحظ أن الرقم ٠٠٠١‏ يهدف إلى تقليل الوقت 
المستهلك في عرض الجداول الضخمة» لكن لو شئت أن تعرض أي عدد 
تريده من السجلات وبأي شرطء فإن الجزء العلوي من النافذة يعرض جملة 
الاستعلام التي تم استخدامها لعرض الألف سجلء ومن ثم يمكنك تعديلها كما 
تشاءء ثم تضغط زر الفأرة الأيمن» ومن القائمة الموضعية تضغط الأمر 
Execute‏ لتنفيذ الاستعلام وعرض ناتجه في الجدول السفلي.. وسنتعلم في 
فصل لاحق كيف نتعامل مع جمل الاستعلام .SQL Queries‏ 


“+ Microsoft SQL Server Management Sbudio اعا‎ × 
File Edit View Query Debug Tools Window Community Help 
ل‎ New Query تا ناف‎ a 4 ك‎ 








# master - ! Execute * " [Û E": ات‎ e Cg C8) ICE عه‎ ET | 
SQLQueryS.oql - ال س ييه‎ Nie _ (S2 - 4ه‎ 
resene com SSNS oer 
SELECT TOP 1000 [ID] 2 
لصعصسوويدق‎ 
0000 0 [dbo] - ] Auchaorca]) 





:Edit Top 200 Rows 
سجل إن‎ ٠٠١ يؤدي هذا الأمر إلى عرض نافذة تحرير السجلات» وبها أول‎ 
وجدت» حيث يمكنك تعديل بيانات السجلات الموجودة أو حذفهاء كما يمكنك‎ 

إضافة سجلات جديدة. 

:Rename 

يؤدي إلى تحول اللافتة التي تعرض اسم الجدول إلى مربع نص» أيمكنك 
تغيير اسمه. . لاحظ أنك تستطيع فعل نفس الشيء مباشرة» بمجرد ضغط 











لافتة اسم الجدول ضغطة واحدة بالفأرة بعد تحديده» تماما كما تفعل مع 
أسماء الملفات في متصفح الويندوز. 

:Delete -‏ 
يؤدي إلى حذف الجدول من قاعدة البيانات» حيث ستظهر لك شاشة تعرض 
اسم الجدول لتأكيد أمر حذفه»ء فإن كنت مصرا فاضغط 016: وإن رجعت 
عن عزمك فاضغط 1ع30).. وطبعا يمكنك فعل نفس الشيء بتحديد اسم 
الجدول وضغط الزر ع126166 من لوحة المفاتيح مباشرة. 

:Properties -‏ 
تعرض نافذة بها خصائص الجدول والكثير من تفاصيله. 


والآن» بعد أن انتهينا من جدول المؤلفين» يمكنك اتباع نفس الطريقة لإنشاء باقي 
جداول قاعدة الكتب» لتكون كتلك التي أنشأناها في آكسيس.. وستجد قاعدة بيانات 
الكتب 800125.12101 على القرص الضوئي المرفق بهذا الكتاب. 


1١ 


أنواع البيانات في فر: 


الجدول التالي يلخص لك أهم أنواع البيانات الخاصة بالأعمدة التي تنشئها في 


سيكويل سيرفر: 
النوع 
bigint‏ 


int 


smallint 


tinyint 
bit 


decimal(x, y) 
أو‎ 
numeric(x, ¥) 


money 


smallmoney 








الحجم 


(Bytes) 
۸ 





الشرح 
عدد صحيح كبيرء وهو يقبل أرقاما من 
-5787 إلى 5787 ١‏ (وهو رقم ضخم جدا 
يساوي تقريبا ٠١‏ مليار مليار). 
عدد صحيح» وهو يقبل أرقاما من 
د ين إلى ۲ ١‏ (وهو رقم يساوي 
تقريبا ۲ مليار). 
عدد صحيح صغيرء وهو يقبل أرقاما من 
١5487-‏ إلى ١ ١585‏ (وهو رقم يساوي 
7۷( 
وحدة ثنائية» وهي تقبل أرقاما من ٠‏ إلى .٠٠١‏ 
خانة ثنائية واحدة» تقبل صفرا أو »١‏ وهي 
مفيدة عند التعامل مع قيم منطقية (وعلآ أم 
(No‏ أو True)‏ أم .(False‏ 
عدد عشر ي٠‏ يتيح لك تحديد الدقة العشرية 
التي تريد التعامل معهاء حيث × تمثل عدد 
أرقام العدد (بحد أقصى ٨‏ رقما)» و ر تمثل 
عدد الخانات العشرية في هذا العدد. 
دقتها العشرية إلى ؛ خانات عشرية» 
وتنحصصر القيم المقبولة بين 
ا ا ل ار رن 
واجلاء له ,لال :157.551 
العشرية إلى ٤‏ خانات عشرية»ء وتنحصر 
القق يم المقبوا ة بين 
“TIEVEASTIEV+ gTIEVEASTTEA-‏ 


1۲ 






































float 


real 


datetime 


datetime2(n) 


smalldatetime 
date 
time(n) 


datetimeoffset(n) 


char(n) 





۸ أو‎ ٤ 


من 1 


إلى ۸ 


٠١ إلى‎ 





عدد عشري مقرب تتحدد مساحة تخزينه 
تنا لد الحانات: العشية المطلوية: فلي 
اخترت أن تكون دقته العشرية ۷ خانات» 
فسيتم حفظه في ٤‏ وحدات و8316 4» أما لو 
اخترت أن تكون دقته العشرية ٠١‏ خانة 
فسيتم حفظه في ۸ وحدات و8326 8. 
عدد حقيقي» وهو حالة خاصة من النوع 
«float‏ فأقصى دقة عشرية له هي ۷ خانات. 
تاريخ ووقت تصل دقته إلى الميلي ثانية 
ممثلة في ۳ خانات عشرية.. مثال: 
12:59:59.9 01/01/1998 
ولا يقبل هذا النوع إلا التواريخ التي تقع بين 
۰۱ ۷/۰و 1444/1/۱ 
تطوير للنوع عرمزاع]12»: يتيح لك التعامل 
مع تواريخ من ١/١/١‏ إلى ..1۹۹۹/۱۲/۳١‏ 
ويمثل الرقم م عدد الخانات العشرية التي 
تريد استخدامها مع أجزاء الثانية.. فمثلا لو 
أردت التعامل مع أجزاء من مئة ألف جزء 
من الثانية» فاجعل قيمة م تساوي 5. 
تاريخ ووقت تصل دقته إلى الدقيقة فقط.. 
مثل: 12:30 01/01/1998 
تاريخ فقط بدون أي وقت» مثل: 
01/01/1998 
وقت بدون تاريخ.. ويمثل الرقم م عدد الخانات 
العشرية المستخدمة لعرض أجزاء الثانية. 
تاريخ ووقت مرفق به فارق التوقيت عن 
التوقيت العالمي.. مثال: 
5+- 12:35:29.123 01/01/1998 
هذا المثال يوضح أن هذا التاريخ مرتبط بموقع 
جغرافي يزيد بساعتين وربع عن توقيت خط 
ويمثل الرقم م عدد الخانات العشرية التي تريد 
استخدامها مع أجزاء الثانية. 
نص ثابت الطول يتكون من عدد م من 
الحروف.. لاحظ أن هذا النوع لا يدعم الكود 






































varchar(n) 








الموسع ع006ن1[010: لهذا ستكون الحروف 
المسموح بكتابتها هي فقط الحروف المتاحة 
على الخادم إعرإم؟ الذي توجد عليه قاعدة 
البيانات.. انتبه لهذا جيداء لأنك في المشاريع 
الحقيقية قد تضع قاعدة البيانات على خادم في 
دولة أجنبية» وبالتالي لن يدعم اللغة العربية. 

ويمكنك التحكم في عدد الحروف» بتغيير 
قيمة الخاصية length‏ من الجزء السفلي 
من نافذة تصميم الجدول» مع ملاحظة أن 
الحد الأقصى لطول هذا النص هو No‏ 
حرف.. والقيمة الافتراضية لطول النص هي 
٠‏ حروف» وفي هذه الحالة لو حاولت كتابة 
نص طوله ١١‏ حرفا فسيرفض سيكويل 
سيرفر ذلكء بينما لو كتبت نصا طوله ۸ 
حروف فسيتم إكماله إلى ٠١‏ حروف بإضافة 
مسافتين في نهايته. 1 

مشابه للنوع هطع في كل شيء إلا في أمر 
واحد» وهو أنه يمثل نصا مرنا متغير الطول 
من الحروف هو 2 (الحد الأقصى لقيمة 17 
هو 6٠٠١‏ حرف).. والقيمة الافتراضية 
mE a‏ يد حوره اح aN‏ 
له كوقه لون نحن مكيل ر 
بينما لو كتبت نصا طوله ۸ حروف فسيتم 
حك ع حوبا جد كا ا عا 
اق ین و کرو فى حال فت 
أطوال النصوص التي ستدخلها في العمود. 

















varchar(MAX) 


text 


nchar(n) 


nvarchar(n) 


nvarchar(MAX) 


ntext 





xn 





هذه الصبيعة حالة خاصة مين الدوع السايق: 
وهي تجعل الحقل يستوعب نصا ضخما 
يصل إلى حجمه إلى ١ 5١67‏ حرفا.. وفي 
هذه الحالة يكون حجم الحقل = عدد حروف 
النص المكتوب فيه + ۲. 

ولا يمكن استخدام عمود من هذا النوع 
كمفتاح ره للجدول أو كمفتاح في أحد 
الفهارس 12016:©5. 

مشابه للنوع ه72 في كل شيء. إلا أنه 
يسمح بحفظ نص مرن متغير الطول يمكن أن 
يصل إلى حوالي ۲ مليار حرف 
3-5189 خرف رو انا لا يقيل هذا 
النوع حروف الكود الموسع 1[210006. 

نص ثابت الطول طوله ى يدعم الحروف 
الموسعة ©1[51000»: لهذا يتم حفظ كل حرف 
في ۲ وحدة 83716 2» ولهذا فإن أقصى عدد 
مسموح به من الحروف في هذا النوع هو 
شرف هذا الشوع متاسف اة 
العربية. 

نص مرن متغير الطول يدعم الحروف 
الموسعة ع1101000» بحد أقصى ٤٠٠١‏ 
كرتم هذا الوح ما للغة رة 


هذه الصتيعة حال خاضة من ا اتاق 
وهي تجعل الحفل يستوعب نصا ضخما 
بل اد مكحن الى 13715 و 
وفي هذه الحالة يكون حجم الحقل 
= ۲× عدد حروف النص المكتوب فيه + ۲. 

نص مرن متغير الطول يدعم الحروف 
الموسعة ©1[010006» بحد أقصى حوالي 
مليار حرف (7057 ١-‏ حرف).. هذا النوع 
مناسب للغة العربية. 





























binary(n) 


varbinary(n) 


Varbinary 
(MAX) 


image 


sqI_variant 


uniqueidentifier 


xml 


Timestamp 


Udt 
Structured 





+n 


ء٤‎ 


أقصى 





بيانات ثنائية ثابتة الطول» وبشرط ألا تزيد قيمة 
م عن 6٠٠٠١‏ وحدة ثنائية و836.. لو اخترت 
م - 50٠‏ متلا وحفظت فى إحدى الخانات 
بيانات تقل عن 5٠‏ وحدة؛ فسيتم إكمال الباقي 
بالعدم 2111 (الحرف رقم ٠‏ في ترميز 
„(ASCII‏ 

بيانات ثنائية مرنة متغيرة الطول» وبحد أقصى 
8 وجدة اة ولو حفط انات طر نها 
قل من و لا بتم إكسال الظول التاقضن باي 
هذه الصيغة حالة خاصة من النوع السابق» 
وهي تجعل الحقل يستوعب بيانات يصل 
حكبيا] ال :5145 12 هده اة وف هذه 
الحالة يكون حجم الحقل = عدد الوحدات 
المكتوبة فيه + .١‏ 

بيانات ثنائية مرنة متغيرة الطول» يمكن أن تصل 
الى خوالن ؟ مليار ويحدة ثنائية ١-3489‏ 
.(Bytes‏ 

متغير عام يقبل باقي أنواع البيانات 


الأنواع التالية: 

text, ntext, timestamp, varchar(MAX) 
معرف عام متفرد 601۲ وهو رقم سداسي‎ 
عشري 10031ع1162206 غير قابل للتكرار.‎ 
يتيح لك هذا النوع تخزين صفحات ,720/11 أو‎ 
أجزاء منها في خانات العمود.‎ 
مصفوفة من ۸ خانات ثنائية» تقوم بإنتاج أعداد‎ 
ثنائية و1836» بحيث تكون المصفوفة متفردة‎ 
عبر كل الجدول» وذلك لاستخدامها في تمييز‎ 
الل خ المحذشة من كل صف‎ 
. Version-Stamping 
.User-Defined Type نوع يعرفه المستخدم‎ 
نوع خاص للبيانات المركبة في صورة جدول‎ 
18016-10؛ وسنتعرف عليه لاحقا.‎ 


515 












































:١ ملحوظة‎ 

عند استخدام أكثر من عمود متغير القيمة (ينتهي بقوسين بينهما طوله (2) )» 
يجب ألا يزيد الطول الإجمالي للسجل ككل عن ۸٠٠٠١‏ وحدة ثنائية 83(6: 
وإلا حدث خطأ.. ولتجاوز هذا الحجم المحدود للسجلء عليك اس تخدام 
المتغيرات 16:4 وغ:216 و 10386 أو المتغيرات الجديدة التي ظهرت في 
سيكويل سيرفر ٠٠٠١‏ وهي تحمل نفس أسماء المتغيرات محددة الطولء لكنها 
تنتهي بالقيمة القصوى (:7013)» وبذلك تتيح لك التعامل مع بيانات يتجاوز 
طولها ۲ مليار وحدة ثنائية 6ا ر8.. كما تتيح لك هذه المتغيرات إمكانيات 
جديدة في كتابة وقراءة البيانات بطريقة تتابعية 56011621121: كما سنرى 
لاحقا. 

لاحظ أيضا أن حفظ أي حروف عربية في حقول من أنواع لا تبدأ بالحرف 1 
سيجعلك تفقدهاء حيث ستتحول إلى علامات استفهام. 


ملحوظة ؟: 

لجعل أحد الحقول ترقيما تلقائياء اختر له نوعا رقميا مناسباء وفي الجزء السفلي 
من النافذة اضغط العلامة + المجاورة للعنصر Identity Specification‏ 
لإسدال خصائصه؛ واجعل للخاصية (1062157 19) القيمة وم۲ لجعل الحقل 
معرفامتفردا.. هذا سيغير قيمة كل من الخاصيتين "معدل الزيادة" 
]dentity 11610101‏ وبذرة الزيادة 5660 116065 إلى القيمة ..١‏ ولو 
أردت أن تبدأ الترقيم التلقائي من العدد ٠‏ مثلاء فضع في الخاصية Identity‏ 
4ع القيمة ..٠٠١‏ ولو أردت أن يزيد ترقيم كل حقل عن السابق له بمقدار ”2 
فضع في الخاصية ٤1ع ],c]e‏ 116117 القيمة ؟. 

ولحل الل فاخا اسا امعط الان الاير الجا لير و الفا + 
الأيمن» ومن القائمة الموضعية اضغط الأمر Primary Key‏ ٤ه..‏ ولو أردت أن 
تتراجع عن جعل الحقل مفتاحا أساسياء فاضغطه بزر الفأرة الأيمن مجدداء ومن 
القائمة الموضعية اضغط الأمر Remove Primary Key‏ 


























انشاء العلاقات في سيكويل سيرفر: 

في متصفح الكائنات 1ع101م18 ]ع0 أسدل عناصر قاعدة بيانات الكتب 
5 » وبزر الفأرة الأيمن اضغط "مخططات قاعدة البيانات" Database‏ 
5 و ومن القائمة الموضعية اضغط الأمر New Database‏ 
.Diagram‏ . سيؤدي هذا إلى عرض نافذة اختيار الجداول التي ستستخدمها في 
رسم المخطط.. حدد جدولا أو أكثر بالفأرةء ثم اضغط الزر 8400 لإضافتها إلى 
صفحة المخططء ثم اضغط ع105) لإغلاق النافذة والانتقال إلى صفحة المخطط.. 
هذه النافذة تشبه نافذة إنشاء العلاقات فى آكسيس» ولكنها تمنحك ميزات إضافية» 
فبإمكانك تغيير أسماء أعمدة أي جدول بمجرد ضغطها وتحريرها في هذا المخطط 
كما يمكذلك ضغط أي حقل بزر الفأرة الأيمن وضغط الأمر Set Primary Key‏ 
من القائمة الموضعية لجعل هذا الحقل مفتاحا أساسيا. 

وفي الوضع الطبيعي» يعرض المستطيل الممثل لكل جدول أسماء أعمدته»ء لكنه 


تستطيع أن تعرض أيضا تفاصيل كل 013555 
عمو د (اسمه 5 ونو ع بياناته ٤‏ وال اح داادالاا ثاداام 53 Column Name‏ كر 
بتركه فارغا)»› وذلك بضغط مستطيل nvarchar(20)‏ 


الجدول بزر الفأرة الأيمن لعرض 
القائمة الموضعية؛ ثم ضغط القائمة 
الفرعية ,5716 ماطه1» وضغط الأمر 513206160.. كما يمكنك اختيار طرق 


2× 
Available columns: Selected columns: ر عرص جه‎ 
٠ Column Name الأساسية الموجودة في‎ 








Scale في‎ 

a 7 

الجدول ا وو re‏ 

Identity Seed ختيا ر‎ 

8 ا ا 5 Increment‏ لسر 

RovıGuld 

Rou Name جدول فقط‎ 

Formula 8 بل ب يمكنك‎ «Only 

Collation ا‎ 2 

تصميم طريقة عرض 5 ا 
خصطة بك 5 

2.2.20 مبديا . | ۽ default‏ جم Save‏ 


ستعرض هذه الطريقة 

تفاصيل الجدول ا اا ا 

الأسا سيةة ولككن 

يمكنك إضافة أية تفاصيل أخرى بضغط الزر 054080" 2/10017» واستخدام 
النافذة التي ستظهر لنقل التفاصيل التي تريد عرضها من القائمة اليسرى إلى القائمة 
اليمنى» وذلك بضغط الزر م 


1۸ 


وكماترى في الصورة أعلاه؛ فقد 
أضفنا عمود القيمة الافتر اضية Condensed Type | Nullable | Default Yalue‏ 


smallint 


للعمودء وهذا سيؤدي إلى عرض nvarchar(20)‏ 
مخطط الجدول كما فى الضسورة.. 
ولو أردت العودة إلى طريقة العرض 
التقليديةء فاضغط الأمر 712065 0112© لعرض أسماء الأعمدة فقط, 

وكما في آكسيس» يمكنك سحب أي حقل من جدول وإلقاؤه على أي حقل في جدول 
آخر لتكوين علاقة بين الجدولين.. سيؤدي هذا إلى ظهور نافذة توضح الجدولين 
والعمودين الداخلين في العلاقة» لتتيح لك تغييرهما إن أردت: 

: تدعت تسا‎ KO TT 7X 


Relationship name: 





FK_Publishers_Countriass1 





Primary kay table: Foreign key table: 
Countriss =| | Publishers 
I0 I0n 


IST ILO TL OES 2 دام‎ 





Selected Relationship: 
FK_ Publishers Countries1=™ 





Editing properties for new relationship. The ‘Tables And © 
Specification" property needs to be fled in before the ney 
لازي‎ be accepted. 


® (General) 

Check Existing Data On 075 
5 Tables And Columns Spec 
Fı Database Designer 
Enforce For Replication Yes 





(Name) FK Publishers Countrias1 





1۹ 





في هذه النافذة يمكنك إدخال اسم العلاقة» وتحديد مواصفاتهاء بطريقة مماثلة للتي 
اتبعناها في وو .. لاحظ أن اسم العلاقة الافتراضي يكون على الصيغة: 

۴K 1 0‏ حيث ۴٣‏ اختصار "المفتاح الفرعي" «Foreign Key‏ و T1‏ 
هو اسم الجدول الأول (الذي يحتوي على المفتاح الأساسي)؛ و 12 هو اسم الجدول 
الثاني (الذي يحتوي على المفتاح الفرعي)»؛ و م هو رقم العلاقة» وهو يبدأ بالرقم 
1 و يمكتك حذفه لو كانت هناك علاقة و احدة فقط نين الول <وعلى كل هال 
يمكنك تغيير هذا الاسم إلى أي اسم آخر يناسبك» بتغيير الخاصية (ع0ة]<) 
الموجودة أسفل النافذة.. كما تحتوي هذه النافذة على الخصائص التالية: 


:Check existing data on creation or re-enabling 
إذا جعلت قيمة هذه الخاصية وم۲ (وهي القيمة الافتراضية)» فسيتم التحقق‎ 
من صحة البيانات الموجودة حاليا في الجدولين» للتأكد من أنها تتفق مع‎ 

شروط العلاقة التي سيتم إنشاؤها. 
:Enforce for replication‏ 
إذا جعلت قيمة هذه الخاصية وم۷ (وهي القيمة الافتراضية)» فسيتم إنشاء 

العلاقة في قاعدة البيانات الجديدة عند نسخ قاعدة البيانات الحالية. 

:Enforce foreign key constraint 
إذا جعلت قيمة هذه الخاصية 65 (وهي القيمة الافتراضية)» فسيتم التحقق‎ 
من قيد المفتاح الفرعي» وهو يتأكد من عدم وجود بيانات في الجدول‎ 
الفرعي مرتبطة بمفتاح غير موجود في الجدول الأساسي. . بعبارة أخرى:‎ 
11616104121 هذا القيد يدفع قاعدة البيانات لتحقيق التكامل المرجعي‎ 
ع6 بين الجدولين» لهذا لو حاولت حذف سجل من الجدول الأساسي‎ 
وكان مرتبطا ببيانات في الجدول الفرعي» فسيحدث خطأ ولن يتم تنفيذ هذه‎ 
العملية.. ولو أردت أن تنفذ عملية الحذف» فعليك أولا أن تحذف السجلات‎ 
ذات الصلة من الجدول الفرعي» ثم تحذف بعدها السجل الأساسي المرتبط‎ 

بها من الجدول الأساسي. 

:INSERT'Ss and 4115 75 

افا دة © المحاور:ة ليذه الخاصيف تهر لك الكاهفيتا التاليتاة : 

» قاعدة الحذف :Delete Rule‏ 
تتحكم هذه الخاصية في ماذا يحدث عندما يتم حذف بعض السجلات 
الداخلة في العلاقة. 

ه قاعدة التحديث :Update Rule‏ 
تتحكم هذه الخاصية في ماذا يحدث عندما يتم تحديث بيانات بعض 
السجلات الداخلة في العلاقة. 

والجدول التالي يوضح القيم المختلفة لهاتين الخاصيتين: 


10 | عدم اتخاذ أي إجراء.. هذه هي القيمة الافتراضية في 











07. 








Action‏ | النافذة, 
0220 | عند تحديث المفتاح الأساسيء يتم تلقائيا تحديث خانة 
المفتاح الفرعي في السجلات المرتبطة به في الجدول 
الفرعي 


وعند حذف سجل المفتاح الأساسيء يتم تلقائيا حذف جميع 
السجلات المرتبطة به في الجدول الفرعي. 

منعدمة 10871111 في خانة المفتاح الفرعي في السجلات 
المرتبطة به في الجدول الفرعي. 

اuوDef‏ | الافتراضية في خانة المفتاح الفرعي في السجلات 
المرتبطة به في الجدول الفرعي. 

اضغط OK‏ لإغلاق النافذة» حيث سيظهر خط بين الجدولين» يمثل هذه العلاقة. 
ملاحظة. 

لكي تنشئ علاقة بين حقلين» يجب أن يكون لهما نفس نوع البيانات ونفس 
الطول» وإلا فسيرفض سيكويل سيرفر إنشاء العلاقة.. لهذا تأكد من أن للمفاتيح 
الأساسية والمفاتيح الفرعية نفس النوع لتصلح للدخول في العلاقات. 

وتستطيع تغيير شكل خط العلاقة بمرونةء بمجرد سحب أي جزء منه بالفأرة» كما 
أن طرف بدايته يأخذ شكل مفتاح للإشارة إلى حقل المفتاح الأساسيء بينما يأخذ 
طرفه الآخر شكل علامة "ما لا نهاية" للإشارة إلى علاقة "واحد بمتعدد". 
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ولمراجعة أو تعديل خصائص العلاقة» اضغط خط العلاقة بزر" الفأرة الأيمن» ومن 
القائمة الموضعيّة اضغط الأمر 616165م25:0.. ستظهر نافذة الخصائص وبها 
خصائص العلاقة» بحيث يمكنك تعديلها كيفما شئت.. أما لو شئت حذف العلاقةء 


الا 
































فاضغط الخط الممثل لها بزر الفأرة الأيمن» ومن القائمة الموضعية اضغط الأمر 
Relationship From database‏ eteاDe»‏ وأكد رسالة الحذف الذي ستظهر لك 
بضغط وم۷ . 
وتتيح لك صفحة المخططات بعض التسهيلات الإضافية: 
- إذ يمكنك متلا أن تغير نسبة العرض 70011 باستخدام القائمة المنسدلة 
الموجودة على شريط الأدوات» أو باستخدام القائمة الفرعية 7000 التي 
تعرضها القائمة الموضعية عند الضغط بزر الفأرة الأيمن في أي منطقة 
كال ابر الات فد 
- كما يمكنك أن تختار أيضا من القائمة الموضعية إضافة تعليق نصي» وذلك 
بضغط الأمر 411018100 1٥×‏ ۸4ء حيث سيؤدي هذا إلى إدراج 
إطاره بالفأرة لتغيير حجمه أو موضعه. ولو ضغطت داخله بزر الفأرة 
الأيمن» فيمكنك اختيار تغيير الخط من القائمة الموضعية وذلك بضغط 
الأمر .Set Text Annotation Font‏ 
- ويمكنك عرض لافتة على خط كل علاقة توضح اسم العلاقةء وذلك 
بضغط الأمر .Show Relationship Labels‏ 
- كما يمكنك عرض خط أزرق يمثل حدود صفحة الطباعة لكي تضمن عدم 
تجاوز الجداول له في حالة رغبتك في طباعة المخططء وذلك بضغط 
الأمر View Page Breaks‏ . 
- وبعد أن تنتهي من تصميم المخططء؛ استخدم الأمر Copy Diagram to‏ 
4 لنسخه كصورة إلى لوحة قصاصات الويندوز› ومن ثم 
يمكنك لصقه في أي برنامج تحرير صور مثل 106 أو حتى 777010 
لتستطيع طباعته أو استخدامه في وثائقك. 
- كمايمكنك طباعة المخطط مباشرة باستخدام الأمرين منااع5 مع۲a‏ و 
+ من القائمة الرئيسية 1"116. 
والآن قم بحفظ هذا المخطط وذلك بضغط 1+8 حيث ستظهر لك نافذة شالك 
عن اسم المخطط.. سمّه 11ه,ع 113 مثلا.. ستظهر لك رسالة تنذرك بأنْ هناك 
تغييرات ستحدث لبعض الجداول لتمنحك الفرصة للتراجع.. لو أردت ألا تظهر لك 
هذه الرسالة في كل مرة؛ فأزل علامة الاختيار من مربّع الاختيار 
..Warn About Tables Affected‏ اضغط وع8 لإتمام العمليّة وإغلاق 
الرسالة. 
لاحظ أنك تستطيع إنشاء أكثر من مخطط وحفظها بأسماء مختلفة.. هذا يتيح لك 
تقسيم العلاقات بين الجداول على أكثر من مخطط وذلك إذا كانت جداول قاعدة 
البيانات كثيرة جدا ومن العسير وضعها كلها معا في مخطط واحد. 


V۲ 


التحكم فى خاد 
يمكنك إيقاف خادم سيكويل عن العمل وإعادة تشغيله في أي وقتء وذلك باستخدام 
مدير تهيئة خادم سيكويل Server Configuration Manager‏ 501.. لفتح هذا 
Start\Programs\Microsoft SQL Server 2008\‏ 
Configuration Tools\ SQL Server Configuration Manager‏ 
وفي النافذة التي ستظهر لك» اضغط العنصر Server Services‏ 5011 من 
الشجرة الموجودة على اليسار: 














. : ا×اصا‎ 
File Action View Help 
ام مزاح | + اي‎ oS 
SQL Server Configuration M | Name Start Mode 
J SQL Server Services SQL Server XPR OT عأ مدوماكاسة‎ 
= إل‎ SQL Server Network Coni | WSQL Server ı1 51511 له‎ Other (Ba.. 
- فق‎ SQL Native Client 10.0 C« | &SQL Server 1 موه‎ yed Other (Bo.. 
8 Client Protocols Pause 
9 Aliases Resume 
Restart 
Properties 
Help 
أن ل‎ 





سيكويل سيرفر نفسها (5011001655) 56171 501.. لو ضغطت هذه الخدمة 
بزر الفأرة الأيمن» فستعرض لك القائمة الموضعية الأوامر التي تتيح لك إيقاف 
مها أو تشغيل 16ج:5 أو إعادة تشغيل 1256216 خادم سيكويل.. وعليك أن تنتبه 
إلى أن إيقاف هذا الخادم سيمنعك من التعامل مع أي قاعدة بيانات موجودة عليهء 
لهذا عليك أن تتأكد أنه يعمل قبل أن تحاول الاتصال به من أي برنامج خارجي.. 
لاحظ أيضا أن حالة الخادم تظل ثابتة (متوقفا كان أم يعمل) عند إغلاق الحاسب 
وإعادة تشغيله.. لهذا إن كنت أوقفته على سبيل التجريبء فلا تنس إعادة تشغيله 
مجدداء واتركه يعمل في سلام ©. 

توصيل وفصل قاعدة بيانات: 

لفصل قاعدة بيانات الكتب من العمل على الخادم» اضغط اسمها بزر الفأرة الأيمن 
في متصفح الكائنات «Object Explorer‏ ومن القائمة الموضعية اضغط القائمة 


NAE 


الفرعية وع[و1: ومنها اضغط الأمر ب[ع72»12: وعند ظهور نافذة تأكيد الأمر 
اضغط 0[1.. قد يحدث خطأ يخبرك بأن هناك عمليات اتصال بقاعدة البيانات 
حاليا.. في هذه الحالة اضغط علامة الاختيار في مربعي الاختيار المجاورين لاسم 
القاعدة في النافذة» لإنهاء عمليات الاتصال بهاء واضغط زر 0O‏ مجددا. 

ولإعادة توصيل هذه القاعدة مرة أخرى» اضغط العنصر sچDatabas‏ في متصفح 
الكائنات بزر الفأرة الأيمن» ومن القائمة الموضعية اضغط الأمر [ع4142» وفى 
افده تو نبل قاعدة البيائات اضغط الزن A8‏ واختر ملت قاعدة البيانات هن 
الموضع الذي حفظتها فيه على جهازك.. ويمكنك أن تضيف أكثر من قاعدة بيانات 
إلى القائمة لتوصيلها كلها مرة واحدة.. بعد هذا اضغط 0 لتوصيل قواعد 
البيانات التي اخترتهاء حيث ستظهر أسماؤها في متصفح الكائنات. 


التعامل مع قواعد بيانات سيكويل سيرفر من دوت نت: 

تدع دوت ك۲ داعبا كابلا للتعام ل مع قواعة بيانناة متيكويل مير فز 
۸. ولا يتوقف الأمر على الاتصال بقاعدة البيانات وقراءة البيانات منهاء بل 
إن الأمر يتعدى ذلك إلى إنشاء قواعد البيانات وتصميم جداولها وعلاقاتها وكل 
ااا من ذاحل نينة التطوين المتكاملة را الفا يدرت تخو يل اك د 
أنه يكاد لا يوجد فارق بين طريقة التعامل مع قاعدة البيانات في دوت نت» وبين 
التعامل معها في مدير سيكويل سيرفر ..SQL Server Management Studio‏ 
الفارق الوحيد هو أنك هنا ستتعامل مع متصفح الخوادم Server Explorer‏ بدلا 
من متصفح الكائنات !Object Explorer‏ 


VE 


إنشاء قاعدة بيانات 8 
افتح متصفح الخوادم Serve Explorer‏ من القائمة wع‏ ]۰۷ واضغط بزر الفأرة 
الأيمن العنصر 6001166011015 Data‏ ومن القائمة الموضعيّة اضغط الأمر 
New SQL Server Database‏ 01316.. سيظهر لك مربّع الحوار الموضتح 
في الصورة التالية: 

ل2 


Enter information to connect to a SQL Server, then spec#y 
the name of a database to create, 


Server name: 


[\sQLExXPRESS =] Refresh 


Log on to the server 
Use Windoyrs Authentication 
r Use SQL Server Authentication 
User name: | 





New database name: 


ج 
سه 41> ] 


في هذه النافذة مطلوب منك أن تكتب اسم خادم سيكويل الذي ستنشئ عليه قاعدة 
البيانات.. اكتب اسم الخادم .MYPC\SQLEXPRESS‏ 

ملحوظة: 

([10©2) موضوعة بين قوسينء أو النقطة "." .. الحكمة في هذا أنك تستطيع 
تغيير اسم جهازك من لوحة تحكم الويندوز 1عمة27 101م00)؛ وفي هذه الحالة 
ستحدث أخطاء في برامجك التي تستخدم الاسم القديم» لهذا فمن الأذكى أن 
تستخدم الاسم .\SQLEXPRESS‏ بدلا من MYPC\SQLEXPRESS‏ . 

ولو كان الخادم محميا باسم مستخدم وكلمة سرء فاضغط الاختيار .501 1796 
»Server Authentication‏ حيث سيتم تفعيل مربعي النص الخاصين بكلمة 























المرور واسم المستخدم.. ولكن نظرا لأننا نستخدم الخادم المحلي بدون حماية» 
فاترك الاختيار الأول .Use Windows NT Integrated Security‏ 
أخيراء اكتب اسم قاعدة البيانات التي تريد إنشائهاء وذلك في مربع النص الموجود 
أسفل النافذة.. اكتب مثلا الاسم و16 واضغط 0K‏ لإغلاق النافذة. 
ستجد أن الاسم 0 .]11655.15 5م2037 قد ظهر في متصفح الخوادم. 
وسيتم إنشاء قاعدة البيانات 151.101 على المسار: 
C:\Program Files\Microsoft SQL Server\‏ 

MSSQL10.SQLEXPRESS\MSSQL\DATA 
ولو شئت أخذ نسخة احتاطيّة منهاء فلا تنس أن تنسخ أيضا الملف‎ 
ولو رفض الويندوز تنفيذ النسخ» فأغلق البرامج المتصلة بقاعدة‎ 15: 10.1.1017 
البيانات» وإن اضطررت فافصل قاعدة البيانات من العمل على الخادم.‎ 


ملحوظة: 

لو ضغطت القاعدة +و16 في متصفح الخوادم 1ع101م18:2 561761 بزر الفأرة 
الأيمن» وضغطت الأمر Delete‏ من القائمة الموضعية فسيتم حذف الاتصال 
بقاعدة البيانات من متصفح الخوادم, لکن لن يتم حذف قاعدة البيانات نفسهاء ومن 
ثم يمكنك إعادة الاتصال بها مرة أخرى من جديد بالطريقة التي سنوضحها 
لاحقا.. لاحظ أن هذا يختلف تماما عما سيحدث في مدير سيكويل 2552/15 
فضنغط الأمر 956181۴ سيعركن نافذة خذف قاعدة البيانات نفسبهاء لذا عليك 
الحذرء استخدام الأمر جاءه]1251511(6 لفصل قاعدة البيانات. 








والآن» أسدل عناصر قاعدة البيانات 1656 في متصفح الخوادم.. لن تشعر بأية 
غربة» فأنت تشاهد نفس العناصر التي شاهدتها في مدير سيكويل من قبلء» ولا 
تحتاج لأن يعلمك أحد كيف تنشئ الجداول أو العلاقات» فلا يوجد أي اختلاف 
يذكرا. . لا أظنك تعتبره اختلافا جذرياء لو أخبرتك أن نقر اسم الجدول مرتين 
بالفأرة يفتح صفحة تصميمهء أو أن الأمر الذي يفعل هذا من القائمة الموضعية 
اسمه "فتح تعريف الجدول" Open Table Definition‏ بدلا من الأمر Design‏ 
في مدير سيكويل» أو أن عرض وتحرير بيانات الجدول يتم باستخدام الأمر 5101 
Table Data‏ بدمنالأمرين: Select Top 1000 [ows‏ 
و 100185 200 م10 ..!E it‏ لاحظ أن نافذة عرض بيانات الجدول التي تظهر بعد 
ضغط الأمر Show rable Daa‏ هي جزء النتائج عمو 6[نوع] في نافذة باني 
الاستعلام 18111061 رمQu»‏ ويمكنك عرض أي جزء آخر بالضغط بزر الفأرة 
في أي موضعء ومن القائمة الموضعية تضغط القائمة الفرعية مه۲ وتختار 
الجزء الذي تريد عرضه. 


كلا 
















: *(ذزوه1.ومع دود إن دواعمبزدم)ءاطه1 :1هاطه1 .مطل‎ - 111055011 12151 _8IX 
لن!‎ ٠.٠ «إيتا- اح م دإ هتف ع إو هات‎ 5-7 
رذ كد] » |يد!‎ CH= | 


3 1] dbo.Table1 
= 
(Name) Table1l 
Databası Teast 
Descripti 
Identity 1 


Indexabi Yes 


CIO ES] 


لاحظ أنك تستطيع تغيير طريقة عرض النوافذ في دوت نت من العرض المتلاحم 
1 إلى العرض الحر.. مثلاء لو نقرت الشريط العلوي لنافذة تصميم الجدول 
مرتين بالفأرة» فستتحول إلى نافذة مستقلة يمكنك تكبيرها وتصغيرها وتحريكها 
خارج بيئة دوت نت كما تريد: 

\sqlexpress.T 
Data Allow 


Type | Nuls | 


bigint 
Name nchar(10} 7 
۳ 


Column Properties | 
E: 


OTS-published No 5 
Full-text Specification No 


Has Non-SQL Server Subscriber No 


Identkty Specfication 





Yes 
(1s Identity) 5 
Identty Increment 1 
Identity Seed 1 
Indexable 


(1s Identity) 














ولو أردث إعانتها إلى وضعها القديه فاشغط شريظ النافذة العلوى زر الفارة 
الأيمن» ومن القائمة الموضعية اضغط الأمر .Dock‏ 


VV 






































الاتصال بقواعد بيانات :SQ£ Server‏ 
نريد الآن الاتصال بقاعدة البيانات 80015.51011 التي أنشأناها بمدير سيكويل.. في 
هذه الحالة سنتبع نفس الخطوات التي اتبعناها عندما أردنا الاتصال بقاعدة البيانات 
Bo0ks.mdb‏ التي أنشأناها في ووععع4: 
- اضغط بزر الفأرة الأيمن العنصر 001226©11005© هاه( في متصفح 
الخوادم» ومن القائمة الموضعيّة اضغط الأمر "إضافة اتصال" 
.Add Connection‏ 
- في مربّع حوار "اختيار مصدر البيانات" 5010106 0212 00056» اختر 
العنصر: Microsoft SQL Server Database File‏ واضغط .OK‏ 
د نتفر لك النافتة الموصيحة في الصورة: 
ا21 


Enter information to connect to the selected data source or click 
"Change" to choose a different data source andor provider. 


Data source! 


[microsoft SQL Server (SqlClient) Change... | 


Server name: 


[.isqLExpRESS 3 Refresh | 


f Log on to the server 


{® Jse Windows Authentication 
f" Use SQL Server Authentication 


User 6 1 
Passyyord! 1 
TF Gaye my password 
fF Connect to a database 


f^ select or enter a database name: 


(® Attach a database file: 


[C:1Books.madf Browse, | 


Logical name: 


n 








Advanced... | 
Test Connection | Cancel | 
و‎ 





Y۸ 

















في النصف العلوي من النافذة» اكتب اسم خادم سيكويل واختر طريقة 
تحقيق الهوية. 

وفي النصف السفلي من النافذة» اختر قاعدة البيانات التي تريد التعامل 
معها.. إذا كانت هذه القاعدة تعمل على الخادم فعلا في هذه اللحظة»ء فاختر 


الخيار 116 or enter a database‏ ectاSe‏ واكتب اسم قاعدة البيانات» 
أو اختره من القائمة المنسدلة.. أما إذا لم تكن قاعدة البيانات متصلة بالخادم 
في هذه اللحظة»ء فاختر 116 023180356 2 طcهAttء‏ واضغط الزر 
Browse‏ واخت ر مل سيق قاعة البيان ات 
(وليكن 800125.57:04) من المجلد الذي حفظته فيه على جهازك.. ويمكنك 
أن تكتب في الخانة مسح 1021ع1.0 أي اسم تريده لتسمية الاتصال به. 
وليس شرطا أن يكون له نفس اسم قاعدة البيانات.. 
أو يمكنك ترك هذه الخانة فارغة. 

- اضغط الزر 6وع7 لاختبار الاتصال.. إذا حدثت مشكلة وأخبرتك رسالة 
الخطأ أن قاعدة البيانات موجودة من قبلء فافتح مدير سيكويل سيرفر 
»SQ1L Server Management Studio‏ وقم بفصل رآع0]ء12 قاعدة 
بيانات الكتب منه» ثم أعد محاولة الاتصال بها من دوت نت.. ويمكنك أن 
تلجأ إلى هذه الخطوة كلما واجهت مشكلة في الاتصال بقاعدة البيانات.. فإذا 
لم يحل هذا المشكلة» فيمكنك عمل 12651 لخادم سيكويل نفسه بالطريقة 
التي شرحناها من قبل. 

- بعد نجاح تجربة الاتصال» اضغط ×0 لإغلاق النافذة.. ستجد أن اسم 
قاعدة البيانات قد ظهر في متصفح الخوادم» ويمكنك التعامل معها بنفس 
الطريقة التي اتبعناها في مدير سيكويل. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النار» وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكانء واهزم أعداءنا وخلصنا من عملائهم 
آمين يا رب العالمين 


۷۹ 


إنشاء الف :Indices‏ 

نريد الآن إنشاء فهرس لأحد الأعمدة في قاعدة بيانات سيكويل.. من المتوقع في 
قاعدة بيانات الكتب مثلاء أن يتم البحث عن اسم الكتاب أو اسم المؤلف.. هذا يعني 
أننا نحتاج إلى فهرسة العمود Authors.Author‏ والعمود ..Books.Book‏ دعنا 
نرى كيف نفعل هذا: 

في متصفح الخوادم» انقر مرتين بالفأرة على اسم جدول المؤلفين 8115015 لفتح 
تصميم الجدول» واضغط بزر الفأرة الأيمن في أي موضع خال من الجزء العلوي 
من صفحة التصميم» ومن القائمة الموضعية اختر الأمر dexes/Keysہ1..‏ 
سيعرض هذا نافذة إنشاء الفهارس والمفاتيح الموضحة في الصورة: 


Selected Primary عراوامنا‎ Key or Index: 


key or index.‏ عراواصدا ممم Editing properties for existing‏ ظ 


El {General} > 
Columns ID (ASC) 
Is Unique جع‎ 













Type Primary Key 
El Identity 





(Name) PK_Authors 
Description 
El Table Designer 
Create ûs Clustered Yes 
Data Space Specification PRIMARY 
Fill Specification ! 7 


Add | Delete | 


كماترىء ستجد تعريفا للمفتاح الأساسي لهذا الجدول واسمه الافتراضي 
»۴K 5‏ وكما ترى من خصائص هذا الفهرس (المفتاح) أنه مرتبط بالحقل 
D‏ ومرتب تصاعديا .A8€٣‏ 

والآن» اضغط الزر 800 لإضافة فهرس جديد.. سيضاف عنصر إلى الشجرة 
الموجودة على اليسار اسمه الافتراضي 175)_11015.. لاحظ أن البادئة ×] هي 
اختصار Index‏ ومن المنطقي افتراض أن الغتصس. الجديد فهرس وليس مفتاحا 
أساسياء لأن الجدول لا يمكن أن يحتوي على أكثر من مفتاح أساسي واحدء بينما 
يمكن أن يحتوي على أكثر من فهرس.. على كل حال» تستطيع تغيير اسم هذا 
الفهرس لو أردتء والآأفضل أن توضح فيه اسم الحقل أيضا.. غير قيمة الخاصية 
Name‏ إلى .IX_Authors_ Author‏ 

علينا الآن أن نحدد الحقل الذي يخصه هذا الفهرس.. اضغط الزر الموجود في خانة 
قيمة الخاصية 0010705.. سيعرض هذا نافذة اختيار أعمدة الفهرس» وهي كما 





Specify the columns and sort order for this Index: 


Column Name | Sort Order 
Auther Ascending 5 


Descending 


Cancel | 





وظيفة هذه النافذة» هي إتاحة الفرصة لك لاختيار أكثر من عمود لتتم فهرستها 
معا.. وكما ذكرنا من قبل» سيتم الترتيب على أساس العمود الأول» فإن تشابهت 
بعض عناصره» فسيتم ترتيبها على أساس العمود الثاني» فإن تشابهت بعض 
الأزواج من العمودين الأول والثاني معاء فسيتم ترتيبها على أساس العمود الثالث... 
وهكذ ا.. كل ما عليك في هذه الحالةء هو الضغط بالفأرة في صف فارغ في النافذة 
واختيار اسم الحقل من القائمة المنسدلة من العمود الأول واختيار نوع الترتيب 
(تصاعديا Ascending‏ آم تنازليا ع010مزوء12) من العمود الثاني.. لكن في معظم 
الأحول لن تحتاج إلا إلى فهرسة عمود واحد كما في حالتنا هذه.. لهذا اختر اسم 
العمود 811412015 واترك الترتيب تصاعديا كما هو وأغلق النافذة بضغط الزر 0K‏ 
للعودة إلى نافذة خصائص الفهرس. 

يمكنك تغيير بعض خصائص الفهرس على حسب احتياجك.. مثلا: لو أردت عدم 
السماح للمستخدم بتكرار أسماء المؤلفين في العمود 11401هرء فاجعل للخاصية 19 
nive‏ € القيمة وم۲ .. وإذا أردت اعتبار هذا الحقل مفتاحا متفردا Unique Key‏ 
للجدول» فاجعل للخاصية عم157' القيمة ع1 10116م[] بدلا من عرع100.. وهكذا. 
أضغط خوول لاغتلاق التافذة و احسقط رن الحفقظ لحفظ التخيير اث التي حك 
للجدول في قاعدة البيانات.. لقد تم إنشاء فهرس حقل المؤلفين الآن! 1 
وبنفس الطريقة. يمكنك إنشاء فهرس لحقل )800 في جدول الكتب. 


۸۱١ 





إنشاء القيود :Constraints‏ 

رأينا كيف ننشئ قواعد التحقق من الصحّة في وومع80.. هنا أيضا يمكن أن نفعل 
المثل.. اضغط بزر الفأرة الأيمن في أي موضع خال من الجزء العلوي من صفحة 
تصميم الجدول 11015ىمء ومن القائمة الموضعية اضغط الأمر عاععط0©) 
5 .ر سيؤدي هذا إلى عرض نافذة إنشاء قواعد التحقق من الصحة:؛ كما 
هي .في الصورة: 

علق 


| Editing properties for existing check constraint. 


El (General) 


Selected Check Constraint: 


Expression 'موهوب' <> #مطااراض‎ 
El Identity 

(Name) CK_ûuthors 

Description 


El Table Designer 
Check Existing Data On Creal fes 
Enforce For INSERTs And UPI es 
Enforce For Replication Yes 








Add | Delete | 





في الخاصية 100ووج1م2:2 اكتب قاعدة التحقق من الصحة.. لاحظ أن هناك 
اختلافا طفيفا عن طريقة كتابة القاعدة في وومءءA,‏ فأنت هنا مضطرٌ إلى إدخال 
اسم الحقل في التعبير» فبينما كانت قاعدة التحقق من الصحّة خاصيّة للحقل في 
و4005 فإئها هنا جزء من الجدول ككل.. هذا يمنحك القدرة على كتابة قاعدة 
معقدة تتحقق من قيمة أكثر من حقل معا.. فمثلاء لاستبعاد صديقنا (موهوب) من 
حقل المؤلفين» اكتب صيغة الشرط كالتالي: 

'موهوب' <> Author‏ 
ولو كانت صيغة الشرط طويلة جداء فيمكنك ضغط الزر الموجود في خانة الشرط 
لعرض نافذة بها مربع نص متعدد الأسطرء لتكتب شروطا طويلة ومعقدة» وعند 
ضغط الزر 0 لإغلاق نافذة الشرطء سيتم التأكد إن كانت صيغة الشرط الذي 
كتبته مقبولة أم لا. 
أغلق النافذة وقم بحفظ التغييرات» ثم انتقل إلى تخطيط الجدول وجرب كتابة اسم 
المؤلف الفذ (موهوب)! 


AY 








الآن» نكون قد ألممنا بأهمّ مفاهيم قواعد بيانات سيكيول سيرفر وكيفيّة إنشائها 
والاتصال بها من دوت نت.. وفي الفصل التالي» سنتعرف على كيفيّة التعامل 
معهاء باستخدام لغة الاستعلام المركبة ر501.. فإلى هناك. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» واهزم أعداءنا وخلصنا من عملائهم 
آمين يا رب العالمين 


AY 


مهداة إلى روح أبي الحبيب 
أ. حمدي كامل غانم» رحمه الله وغفر له وأسكنه فسيح جناته 





كل يوم في صلاة الفجر ذكرى 
حينما تبكيك أَمّي بدموع الحزن مرا 


غير" أدسة هاما ر نه كنك ا 


A٤ 


كنت فيها تزرغ الأيامَ صبرا 
لم تفارق يا أبي 
كل شيء في حنايا البيت يَحكي عنك عطرا 
ها هنا في دفء شمس كنت تقضي الصبح تكرّى 
ها هنا صليت فرضاء أو شربت الشاي عصرا 
ها هو الجوال رد على سؤالك 
تفت التلفاز : 'فاز في مباراة الزمالك" 
'إنه الأهلي وهذي خير بُشرى" 
تسمع الأخبار تبكي فرحة الثوار لمّا صرت حرا 
تسمع الأخبار أخرى ثم تبكي هم مصرًا 
"إن بعد العسر يُسرا" 
كنت فردا يا أبي.. والآنَ تحيا ألف ذكرى 
طبت في الأحياء ذكرا 
طبت في الأموات قبرا 
طبت في دنياي عُمرا 


محمد حمدي غانم 


لسنوات طويلةء اعتاد أبي وأمي أن يستيقظا قبل صلاة الفجر بساعة» يتسامران 
ويدعوان لناء انتظارا للصلاة.. الآن أسمع أمي تبكي وقت الفجر.. كان أبي وأمي 
في حوار دائم منذ خطبها وإلى يوم مماته.. وكان آخر هذا الحوار في المستشفى 


ليلة وفاته» حينما قالت له أمي: 


Ao 


- لا تغضب مني لأني تأخرت عليك اليوم. 
فأجابها: 
وأسند رأسه على كتفها ونام» وتوفي وقت الفجر. 
هذه أجمل قصة حب رأيتها في حياتي.. لا ينفي هذا أنهما كانا يتشاجران أحيانا أو 
يحتدان في الحوارء لكنهما سريعا ما يتصالحان.. لم أرَ في زوجين آخرين مثل 
تلك الألفة التي كانت بينهما. 
رحمك الله يا أبي» وجعل حسن عشرتك في ميزان حسناتك» وغفر لك وأدخلك 
الجنة بغير حساب. 
وحفظ الله أمي وأنعم عليها بالصحة والعافية وبارك في عمرها. 


أسألكم الدعاء لأبي وأمي 
ومن يستطيع أن يعمل عمرة لأبي فلا يبخل عليه بها. 
وجزاكم الله خيرا 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكانء واهزم أعداءنا وخلصنا من عملائهم 
آمين يا رب العالمين 


كم 


2 
لغ ةالاستعللامالركبة 


Structured Query Language (SQL) 


مهما كان نوع تطبيق قاعدة البيانات الذي تتعامل معه» فإنه يستخدم لغة خاصّة 
بقواع د البيانات متفقا عليها دوليا اسمها ,901 (تنطق "اس كيو إل" أو 
"سيكويل").. صحيح أن هناك اختلافات في تركيب هذه اللغة بينَ تطبيق وآخرء 
ولكنها اختلافات ie‏ لا تكفي للادعاء بأنها نسخ مختلفة تمام الاختلاف. 
وبالمقارنة بلغات البرمجة المألوفةء تعتبر ,5)0[1 لغة غير إجرائية -مره1[10 
60181 فهي لا تحتوي على تركيبات لغوية مثل جمل الشرط وجمل التكرار 
وما شابهها.. وتعتبر ,501 لغة برمجة عالية المستوي» حيث يمكنها في سطر 
واحد إجراء عمليّات بليغة التعقيد على قاعدة البيانات. 


ملحوظة: 

يقدم لنا موعكرع5 ,501 لغة إجرائية تسمى ,1-5001 وهي تستخدم جمل ,5001 
المخزنة Procedures‏ 00 كما سنرى لاحقا.. لكن نظرا لأن لغة 
7-01 أكبر من أن نغطيها هناء فسنتركها إلى كتاب لاحق بإذن الله. 


وتنقسم جمل لغة ,5001 إلى طائفتين رئيسيّتين: 

:Data Manipulation Language (DML) لغة التعامل مع البيانات‎ -١ 
وتختص باسترجاع أو تحديث أو إضافة أو حذف السجلات التي تحقق‎ 
شروطا معيّنة» لهذا تسمى بالاستعلامات sعاQuer. . وتسمّى جمل استوجاع‎ 
البيانات باستعلامات التحديد 6©0061165 102]ء5616»: بينما تسمّى جمل‎ 
.Action Queries الحذف والتعديل والإضافة باستعلامات الفعل‎ 

؟- لغة تعريف البيانات :Data Definition Language (DDL)‏ 
وتختص بإنشاء أو حذف كائنات قاعدة البيانات» كالجداول والأعمدة 
والفهارس والعلاقات والقيود 005):2105. 








AV 











باني الاستعلام :Ouery Builder‏ 
لكي تجرّب الأمثلة التي سنشرحها في هذا الفصلء يمكنك استخدام نافذة تسمى 
"باني الاستعلام" Builder‏ 137ع011» لإنشاء جمل ,501 بطريقة مرئيّة 1/151121. 
ولعرض باني الاستعلام» أسدل عناصر قاعدة البيانات 80015 في متصفح خوادم 
الإنترنت بزل الفأرة الأيمن.. ستجد ضمن عناصر قاعدة البيانات عنصرا اسمه 
9. تحت هذا العنصر يمكنك أن تنشئ العغروض 1/1675. 
اضغط العنصر 7716978 برز الفأرة الأيمن» ومن القائمة الموضعيّة اضغط الأمر 
New View‏ 00ى.. ستظهر لك نافذة "إضافة جدول" 12616 400» وهي 
تحتوي على أسماء جداول قاعدة بيانات الكتب.. حذد الجدولين sإAutho‏ 
و 80015 واضغط الزرّ 400ء ثم الزر ©105©. 
الآن أنت ترى نافذة باني الاستعلام» التي تتكوّن من أربعة أجزاء وعمو7 4: 
- جزء المخطط .Diagram Pane‏ - جزء المعايير .Criteria Pane‏ 
- جزء جملة الاستعلام .SQL Pane‏ - جزء النتائج .Results Pane‏ 
وتستطيع عرض أو إخفاء أي جزء من هذه الأجزاءء وذلك بضغط باني الاستعلام 
بزر الفأرة الأيمن» وضغط اسم الجزء المطلوب من القائمة الفرعية .Pane‏ 
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:Diagram Pane قسم المخطط‎ 

ستحصل على البيانات منها.. هذه الجداول تظهر في صورة مشابهة للتي رأيناها 
في مخططات قاعدة البيانات .Database Diagrams‏ 

ويمكنك حذف أيّ جدول بضغطه بالفأرة» وضغط الزرٌ معام من لوحة 
المفاتيح.. ولإضافة الجدول مرّة أخرى» اضغط بز ر الفأرة الأيمن في أي موضع 
من المخطط. ومن القائمة الموضعيّة اضغط 19116 ›Add‏ لتظهر لك نافذة إضافة 
جدول. 

وإذا كانت هناك علاقات قد تمّ إنشاؤها بين الجداول سابقاء فستجد الخطوط التي 
توا م مون الا و كنا كنك اا العلافاك يون الها رل سحب 
اسم الحقل من الجدول الرئيسي وإسقاطه على اسم الحقل في الجدول الفرعي» بنفس 
الطريقة التي تعلمناها عند التعامل مع مخططات قواعد البيانات. 

وفي حالتنا هذه سيظهر خط يصل بين الحقل (11 في جدول المؤلفين» والحقل 
110 في جدول الكتب» وعلى منتصف هذا الخط سيظهر رمز يمثل نوع 
الربط الذي سيتمٌ تنفيذه في جملة ,501 ما بين الجدولين.. لاحظ أن للربط أنواعا 
عديدة» يمكن اختيارها بضغط الرمز بزر الفأرة الأيمن لعرض القائمة الموضعيّة. 
ويمثل شكل الجوهرة ربطا داخليًا رزه[ #عممآء وهذه هي القيمة الافتراضيّة ما لم 
تختر أنت غير ذلك.. (سنفهم معنى هذه الارتباطات لاحقا). 

أوّل خطوة لبناء جملة ,501 هي اختيار الحقول التي ستظهر في النتيجة.. لفعل 
هذا اضغط بالفأرة مربّع الاختيار على يسار كل حقل تريد إضافته. . فإذا كنت تريد 
إضافة كل حقول الجدول مرّة واحدة» فاضغط مربّع اختيار العنصر 
(05طن001) 411).. وفي مثالنا هذاء اختر الحقل 11001 من جدول المؤلفين» 
والحقل )800 من جدول الكتب» لنعرض أسماء المؤلفين وكتب كل منهم. 


قسم المعايير :Criteria Pane‏ 
بغر كوهد a‏ بط افراع 'الحقر ل الوك كارا فى :كع 
المخططة ويتيع لك تحديد الخير وط والمعابيو التي ترمد ها على هذه الحتول: 

لاختيار بيانات معينة منها. 

ويمكنك أن توضح أن بعض هذه الحقول تستخدم فقط لقراءة البيانات منهاء لكن 
دون أن تظهر في النتيجة.. لفعل هذا أزل العلامة (”7) من خانة العمود 16ام)11© 
المناظرة لهذه الحقول. 

وتمثل خانة "الاسم المستعار" 41135 الاسم الجديد الذي تريد عرض العمود به في 
النتيجة.. فقد لا تريد مثلاء أن تعرض لمستخدم برنامجك أسماء المؤلفين العرب 
تحت عمود اسمه 0۲ طاںا۸» وبدلا من هذا تريد أن تمنح لهذا العمود الاسم 
المستعار "المؤلف".. أيضاء يمكنك أن تعرض الحقل 8001 بالاسم "الكتاب". 


۸۹ 


وهناك حالة أخرى تحتاج فيها لاستخدام الاسم المستعارء تلك إذا كانت النتيجة 
تحتوي على عمودين أو أكثر من جداول مختلفة لها نفس الاسم» فتحتاج إلى 
التفريق بينها قبل ر ضما للمستخدم. 

ويمكنك ترك الخانة ووا فارغة إذا لم تكن تريد استخدام اسم مستعار. 

وسنتعرف لاحقا على كيفية استخدام جزء المعايير عمه2 0216112 لإضافة 
الشروط المطلوب تطبيقها على الحقول. 


قسم الاستعلام Pane‏ ,501: 

في هذا الجزء يظهر نص جملة 5Q1‏ المولد آليا نتيجة اختياراتك التي أجريتها 
في قسم المخطط وقسم المعايير.. هذا يجعلك بقليل من الملاحظة تتعلم لغة 1[ ©5» 
وذلك بتجريب بعض التغييرات في المخطط وجدول الحقول وملاحظة تأثيرها على 
جملة 1[ 5©0. 

وبإمكانك التعديل في جملة ,5001 المكتوبة في هذا القسم على حسب ما يناسبك» 
وسيظهر أثر هذا التعديل في جزء المخطط وجزء المعايير.. وبإمكانك أيضا كتابة 
أي جملة 501 (أو لصقها) في هذا القسم لتجريبهاء كما يمكنك أن تنسخ جملة 
1 من هنا لتستخدمها في أي موضع آخر من برنامجك. 

ولكن.. إلى الان لم يتم تنفيذ الاستعلام» ولم نختبر ناتجه! 

اضغط بزر الفأرة الأيمن في أي موضع من باني الاستعلام» ومن القائمة الموضعيّة 
اضغط الأمر 0617© وں۸)؛ أو اضغط الاختصار 01+12 من لوحة المفاتيح 


مباشرة. 


قسم النتائج :Results Pane‏ 
النتائج بزرٌ الفارة الآيمن» ومن القائمة الموضعيّة اختر الآمر .Clear Results‏ 


بعدأن تنتهي من تصميم عرض البيانات س۷1 احفظه بالاسم 
›Authors_ Books‏ ثم أغلق نافذة باني العام . الآن سيظهر الاسم 
Authors_ Books‏ تحت العنصر 17165 في متصفح الخوادم» ولو أردت إعادة 
تصميم هذا العرضء فاضغطه بز ر الفأرة الأيمن» ومن القائمة الموضعيّة اضغط 
الأمر 1/16 2ع 1و12» أو اضغط اسم العرض مرتين بالفأرة مباشرة.. سيعرض 
هذا باني الاستعلام وفيه تفاصيل الاستعلام الخاص بهذا العرض. 

ويمكنك أيضا أن تضغط اسم العرض 4115015_1280015 بزر الفأرة الأيمن» 
واختيار الأمر sأاuاومR‏ 56017 من القائمة الموضعية.. سيعرض هذا جدولا 


كانت هذه نكرة سريعة عن باي الاستعاتم» ليمكتك استخذامه فى تجرية حمل 
901 التي سنشرحها في المقاطع التالية.. كل ما عليك هو نسخ الجملة إلى قسم 
501 وضغط K]۲1+8‏ لتنفيذها.. وسنتعرّف على باقي إمكانيّات باني ا 
أثناء شرحنا لجمل ,5001» حيث سننوه إلى كيفيّة استخدامه لبناء كل جملة. 

لاحظ أنك لا تحتاج إلى إنشاء عرض 77167 جديد لكل جملة استعلام تريد 
تجربتهاء فبإمكانك ضغط العنصر 7/167/9؟ بزر الفأرة الأيمن» وضغط الأمر 
"استعلام جديد" رإمQu‏ 221677 فهذا سيؤدي إلى عرض نافذة باني الاستعلام 
لتجرب فيها ما تشاء» وبعد هذا تغلقها دون حفظ التغييرات. 

والآن» دعنا نتعرف على لغة الاستعلام المركبة 1 50. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» واهزم أعداءنا وخلصنا من عملائهم 
آمين يا رب العالمين 


Selection Queries استعلامات التحديد‎ 


تستخدم هذه الاستعلامات للحصول على بعض البيانات من قاعدة البيانات أو إضافة 
بيانات جديدة إليهاء أو تعديل أو حذف بيانات موجودة فيها.. وفيما يلي نتعرف على 
أهم جمل هذا النوع من الاستعلامات: 


:SELECT Statement جملة التحديد‎ 





تمكنك الجملة 51:11:01 من استرجاع جزء من صفوف الجدول.. وأبسط صورة 


لهذه الجملة هي: 
أسماء الأعمدة SELECT‏ 
أسماء الجداول FROM‏ 
لاحظ مايلى: 
-١‏ جمل ,501 غير حساسة لحالة الأحرف» لكن جرى العرف على كتابة 


كلماتها المفتاحية كاملة بحروف كبيرة 1621م03) على سبيل التمييزء لهذا لو 
كتبت 01ه1ه5 فلن تختلف عن 6عه5616 ولا عن 8)1 S٤1‏ في شيء. 
أسماء الأعمدة والجداول يفصل بينها العلامة ",".. مثال: 
SELECT Author, Book‏ 
FROM Authors, Books‏ 
لاحظ أنك لو جرّبت هذا المثال فستفاجأ بنتائج غريبة» حيث سيتم تكرار كل 
سجل من سجلات المؤلفين مع كل أسماء الكتب» مما يبدو معه أن كل مؤلف 
قد ألف كل الكتب!.. هذا خطأ متوقع؛ لأننا لم نضع أي شرط يوضح طريقة 
الربط بين حقول الجدولين» وهو ما سنتعلمه بعد قليل. 
إذا كان اسم الجدول أو اسم الحقل يحتوي على أيّة رموز غير مقبولة برمجيًا 
(مثل المسافات أو العلامات ":" أو "+" أو "=" ... إلخ) فيجب وضعه بين 
قوسين مضلعين [ ].. وعامة» يمكنك وضع اسم أي جدول أو اسم أي حقل 
بين قوسين مضلعين.. مثال: 
SELECT [Author], [Book]‏ 
FROM [Authors], [Books]‏ 
إذا تشابهت بعض أسماء الحقول في أكثر من جدول» فيجب التمييز بينها 
بكتابة اسم كل حقل على الصيغة: (اسم الجدول.اسم الحقل).. وعموماء يمكنك 
كتابة اسم الجدول قبل اسم أي حقل حتى ولو لم يكن له شبيه.. مثال: 
SELECT [Authors].[Author], [Books].[Book]‏ 
FROM [Authors], [Books]‏ 
ويمكنك إزالة الأقواس المضلعة إذا لم تكن هناك حاجة إليها: 
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SELECT Authors.Author, Books.Book 

FROM Authors, Books 

-٥‏ ستظهر الحقول في السجلات المعادة بالترتيب الذي كتبت أسماءها به في 

جملة ..S8 1٤٣1‏ هذا يعني أن الحقل 1101 سيظهر أولا ثم الحقل 
8001 في نتيجة الاستعلام السابق. 

5- يمكنك كتابة جملة .501 على أكثر من سطرء فهي ليست كأوامر فيجيوال 
بيزيك تنتهي بنهاية السطرء ولكنها كأوامر K++‏ تنتهي بالفاصلة المنقوطة 
":" وإن كان من الممكن عدم كتابة الفاصلة المنقوطة كاختصار.. هذا معناه 
أن الجملة التالية صحيحة: 

SELECT Author, Book FROM Authors, Books 
لكن تقسيمها على سطرين يجعل قراءتها أسهل.. هذا مجرد تنسيق.‎ 

۷- معظم الأخطاء التي تحدث في كتابة جملة ,5001 تنتج عن الخطإ في كتابة 
أسماء الحقول والجداول» فانتبه لذلك جيّدا. 

۸- لتحديد كل سجلات الجدول» يمكنك كتابة أسمائها جميعا والفصل بينها 
بالفاصلة.. ولكن هذا سيكون مأساويا لو كان الجدول يحتوي على عشرين 
عمودا مثلا!.. لهذا تمنحك ,501 تسهيلا رائعاء وهو استخدام العلامة "*" 
(أو الكلمة ,41.1) للدلالة على تحديد كل أعمدة الجدول كالتالي: 

SELECT * 

FROM Authors 

أو: 

SELECT للك‎ 

FROM Authors 
ولو أردت استرجاع كل الحقول من جدولين» فاستخدم جملة كالتالية:‎ 

SELECT Authors.*, Books.* 

FROM Authors, Books 

4- يمكنك كتابة اسم مختصر للجدول بعد اسمه الحقيقيَ مباشرةء واستخدامه في 

باقي جملة الاستعلام للتسهيل.. مثال: 
SELECT A.*, B.ID, B.Book‏ 
FROM Authors A, Books B‏ 
كما يمكنك استخدام الكلمة ۸5 بين الاسم الحقيقي والاسم المختصر كالتالي: 
SELECT A.*, B.ID, B.Book‏ 
FROM Authors As A, Books As B‏ 


:WHERE Clause الفقرة 'حيث'‎ 


لم تخترع قواعد البيانات لكي تقرأ منها كل سجلات الجدول كما أدخلتهاء فالأهمٌ من 
هذا هو قدرتك على حساب بعض النتائج واستخلاص المعلومات من هذه 
السجلات.. هنا يبرز الدور الحيوي للفقرة HR ٤۴‏ ۷» فهي تسمح لك بتحديد 
الشروط التي سيتمٌ على أساسها استرجاع السجلات» بحيث تحصل فقط على 
السجلات التى تحقق هذه الشروط. 
ون تكون ةة هذه الققرة صخ عك فة القدر ل القافيةة يها داك 
للشروط التي تعودت كتابتها في جملة +1 في لغة فيجيوال بيزيك. 
والمثال التالي يسترجع كل الكتب التي يحمل مؤلفها الرقم ١‏ أو ٣‏ 
SELECT Book‏ 
FROM Books‏ 
WHERE AuthorID = 1 OR AuthorID = 3‏ 
ولكن من هو المؤلف رقم ١‏ ومن هو المؤلف رقم ؟؟ 
هذه الطريقة تبدو عديمة الجدوى» فهي غير عمليّة في البرمجة!.. إننا تريد أن 
نعرف الكتب التي ألفها (توفيق الحكيم) مباشرة دون أن تبحث عن رقمه أولا.. لا 
بأس إذن فهناك حل.. دعنا نستخدم الجملة التالية: 
SELECT Book‏ 
FROM Books, Authors‏ 
AND AuthorID = Authors.ID‏ 'توفيق الحكيم' = WHERE Author‏ 
لاحظ أننا كتبنا اسم جدول المؤلفين في الفقرة 7190174 رغم أن أيا من حقوله لن 
يظهر في النتيجة» وذلك لأننا نستخدم حقول هذا الجدول في الفقرة .W 1٤ R٤۴‏ 
والآن هذا ما سيحدث: سيتمٌ اختيار السجلات التي تحمل اسم (توفيق الحكيم) في 
جدول المؤلفين» ثم اختيار السجلات من جدول الكتب التي يتساوى فيها رقم المؤلف 
مع رقم المؤلف في السجلات المختارة من جدول المؤلفين.. ونظرا لأنه لن يوجد 
سوى رقم (توفيق الحكيم) فحسب» فإن كتبه فقط هي التي سيتم عرضها. 
ومن الممكن تبديل ترتيب جملتي الشرط فالترتيب ليس مهماء حيث تقوم قاعدة 
البيانات بتنفيذ الشروط على حسب أولويّة تنفيذهاء وليس على حسب ترتيب كتابتها: 
SELECT Book‏ 
FROM Books, Authors‏ 
'توفيق الحكيم' = WHERE AuthorID = Authors.ID AND Author‏ 
والآن تعال نطوّر المثال السابق» لنحصل على كل الكتب التي ألفها (توفيق الحكيم) 
أو (عباس العقاد).. في هذه الحالة لا بذ من عرض اسم المؤلف في النتيجةء وإلا 


SELECT Book, Author 
FROM Books, Authors 
WHERE (Author = 'توفيق الحكيم'‎ OR Author = عباس العقاد'‎ ') 
AND AuthorID = Authors.ID 
ولكن ماذا لو أردنا أن نعرض كل أسماء الكتب مع ما يناظرها من مؤلفين؟‎ 
سيكون الأمر في منتهى البساطة» فسيقتصر الشرط في هذه الحالة على تساوي رقم‎ 


المؤلف في الجدولين: 
SELECT Book, Author‏ 
FROM Books, Authors‏ 
WHERE AuthorID = Authors.ID‏ 
ملحوظة: 


يمكنك استرجاع جدول فارغ بوضع شرط خاطئ أو مستحيل في الفقرة 
WHERE‏ (مثل )١ = ١‏ كالتالي: 
SELECT *‏ 
FROM Books‏ 
WHERE 1 =2‏ 
يفيد هذا عندما تريد أن تحصل على سجل فارغ يحمل أسماء حقول الجدولة 
كاملة بدون بيانات» بحيث تسمح للمستخدم بإدخال سجلات جديدة» لكن دون 
العبث بالسجلات القديمة. 








انشاء الفة3 WHERE‏ بباني الاستعلام: 

لكي تضيف شروطا في باني الاستعلام على الحقول التي تريد استرجاعهاء حدد 
الحقل في جزء المخطط لإضافته إلى جزء المعايير 206 016112).. دعنا نجرب 
مثلا على الحقل 17 في جدول المؤلفين. 

ستجد في جدول المعايير عمودا اسمه إم)[۳.. هذا هو العمود الذي تستطيع أن 
تكتب فيه الشرط الذي تريده» لكن بدون كتابة اسم الحقل. . مثلاء لكي نحصل على 
كتب المؤلف رقم 5» اكتب في الخانة )۴1 في صف الحقل «11 الشرط: 


ولو أردت المؤلفين الذين يزيد رقمهم عن 5» فاكتب الشرط: 

5> 
وهكذا.... 
وإذا أردت أن تكتب شرطا آخر مرتبطا بالشرط الأول بالمعامل «20[1» فانتقل إلى 
العمود التالي الذي يحمل العنوان »0R‏ واكتب الشرط الذي تريده في هذا العمود.. 
فإذا كان هناك المزيد مان الشدروط:فلديك المزيد مين الأعمدة التي تعمل اران 


4° 











0 .. فمثلاء لو أردت أن تحصل على المؤلفين الذين أرقامهم ۷و ١١و‏ ١٠ء‏ 
فاجعل صف الحقل (11 في جزء المعايير يبدو كالتالي (سأقتصر على ذكر الأعمدة 


Column ١ Table Filter Or Or 
ID Authors = 7 = 2 = 0 




















ولكن ماذا لو أردت أن تكتب شرطا يستخدم المعامل A۸D؟‏ 
في هذه الحالة يجب أن يظهر هذا الشرط في صف جديد.. فمتلاء لو وضعت في 
العمود ه1011 شرطا على رقم المؤلف (11 وشرطا على اسم المؤلف إ0طاAuء‏ 
فسيتم ربط الشرطين معا بالمعامل ([01لل. 
ولكن.. ماذا لو أردنا أن يظهر نفس الحقل في أكثر من شرط يربطها المعامل 
0D‏ كأن نستعلم عن كل المؤلفين ما عدا المؤلفين رقما ۸ و 1؟ 
في هذه الحالة يجب أن نكرر اسم الحقل (11 في جزء المعايير.. لفعل هذا اضغط 
بالفأرة في أي خانة فارغة في العمود المسمّى 00[1:0» ومن القائمة المنسدلة 
اختر الحقل .Authors.1D‏ 
الآن صار لديك صفان للعمود (11.. اكتب في العمود ه114 للأول الشرط: 

8 <> 
واكتب في العمود ۴]]6۲ الخاص بالثاني الشرط: 

9 >< 
ولكن ماذا لو كان هناك شرطان كل منهما على حقل مختلف» ويربطهما المعامل 
+01.» كأن تريد اختيار المؤلف الذي رقمه 5 أو اسمه توفيق الحكيم؟ 
في هذه الحالة اكتب في العمود ه711 الخاص بالحقل (11 الشرط: 


6 = 
واترك العمود م,ع1771 الخاص بالحقل 1101 فارغاء واكتب في العمود O0۴‏ 
الخاص به الشرط: 
اتوفيق الحكيم' = 
الخلاصة٠‏ 


الشروط التي تظهر في العمود إع)[ز۴ في صفوف مختلفة يربطها المعامل 
۷0D‏ بينما الشروط التي تظهر في العمود 0R‏ يربطها المعامل +01.. ولو 
أردت ربط حقلين بالمعامل 01 فاترك العمود ,ه116 الخاص بأحدهما فارغاء 
واكتب الشرط الخاص به في العمود +[0. 

معاملات المقارنة: 

الجدول التالي يلخص المعاملات التي يمكن استخدامها لتكوين شروط مركبة مع 
الفقرة :WHERE‏ 


























المعاملات المنطقية 
و AND‏ 
أو 02 
NOT 5‏ 
معاملات المقارنة 
يساوي - 
لآ يساوي <> 
أكبر من > 
أصغر من > 
أكبر من أو يساوي => 
أصغر من أو يساوي => 











فمثلا للحصول على أول ۸ كتب في جدول الكتب: 
SELECT ID, Book‏ 
FROM Books‏ 
WHERE ID <9‏ 
وللحصول على الكتب التي تسبق كتاب "حائرة في الحب" في الترتيب الهجائيء 
استخدم الجملة التالية: 
SELECT ID, Book‏ 
FROM Books‏ 
'حائرة في الحب' < WHERE Book‏ 


المعامل 'بين' :BETWEEN Operator‏ 
يسمح لك هذا المعامل بتحديد المجال الذي ينتمي إليه الحقل.. فمثلاء يمكننا استخدام 
الحملة الثالذة ال على "لكف الى يتخضر ار ها نين ع 
SELECT Book, Price‏ 
FROM Books‏ 
WHERE Price BETWEEN 3 AND 10‏ 
كما يمكننا استخدام N01‏ قبل هذا المعامل للحصول على قيم الحقل التي لا تنتمي 
إلى المجال المحدد.. والجملة التالية تعيد الكتب التي لا تنحصر أسعارها بين ” و 
٠‏ جنيهات: 
SELECT Book, Price‏ 
FROM Books‏ 
WHERE Price NOT BETWEEN 3 AND 10‏ 






































المعامل 'في' :IN Operator‏ 
أحيانا لا يحل المعامل 8171777111717 كل مشاكلناء فماذا لو أردنا أن نختار قيما 
متفرّقة للحقل؟.. في هذه الحالة سيؤدي استخدام المعامل ۸N‏ إلى كتابة جملة 

طويلة جدا. 
هنا تبرز أهمية المعامل »[N‏ فبعده توضع كل القيم بين قوسين مفصولة 
بالعلامة , .. والجملة التالية تعيد إليك الكتب التي تحمل الأرقام ١‏ و “و ۷و :٠١‏ 
SELECT ID, Book‏ 
FROM Books‏ 
WHERE ID IN (2, 6, 7, 10)‏ 
ويمكن نفي الجملة السابقة للحصول على باقي الكتب (التي لا تحمل الأرقام 
المذكورة) كالتالي: 
SELECT ID, Book‏ 
FROM Books‏ 
WHERE ID NOT IN )2, 6, 7, 10) 1‏ 
ولا يقتصر الأمر على الأرقام؛ فالجملة التالية تعيد كل الكتب التي ألفها (توفيق 
الحكيم) و(نبيل فاروق) و(أحمد رجب): 
SELECT Book, Author‏ 
FROM Books, Authors‏ 
WHERE AuthorID = Authors.ID‏ 
('أحمد رجب' , 'نبيل فاروق' ,'توفيق الحكيم') AND Author IN‏ 


المعامل 'يشبه" :LIKE Operator‏ 
يستخدم هذا المعامل في الفقرة 1772111011 بنفس الطريقة التي يستخدمه بها 
ستدركها عند التعرّف على العلامات الخاصّة التي يستخدمها هذا المعامل» وهي: 


الرمز الوظيفة 
% |تعبّر عن أي عدد من الحروف (يمكن أن يكون هذا العدد صفرا)؛ مهما 
كانت هذه الحروف. 


مثال: استخدم الجملة التالية للحصول على جميع أسماء المؤلفين التي 
تحتوي على حرف الميم في أي موضع: 
SELECT Author‏ 
FROM Authors‏ 
م WHERE Author LIKE‏ 
ولو أردت أن تبحث عن المؤلفين الذين يبدأون بحرف الميم» فاستخدم 
الصيغة ام . 
تعر عن حرف واحد فقطء مهما كان هذا الحرف. 
مثال: استخدم الجملة التالية للحصول على جميع أسماء المؤلفين التي 
يكون حرف الميم فيها هو ثالث حرف: 
SELECT Author‏ 
FROM Authors‏ 
'%م " WHERE Author LIKE‏ 
حيث استخدمنا علامتي " " 1 ووو (أي 
حرفين) يليهما الحرف الثالث وهو المي ؛ يليه العلامة % لتتل على أن 
أي عدد من الحروف مهما كانت يمكن أن يأتي بعد حرف الميم؛ > بمافي 
ذلك أن يكون حرف الميم هو آخر حرف في النص ولا تليه أية حروف. 
# | تعبّر عن رقم منفرد من ٠‏ إلى 1. 
[] تعبّر عن حرف واحدٍ من الحروف الموجودة بين القوسين.. هذه 
الحروف إمّا أن تُكتب متتالية مثل: 
[ACdF]‏ 
وإمّا أن ثكتب على صورة مجالء مثل: 
ا-8] 
حيث تعبر هذه الصيغة عن الحروف من ع إلى ل8. , 
مثال: استخدم الجملة التالية للحصول على جميع أسماء المولفين التي 
يكون حرف الميم أو النون أو الواو فيها هو ثالث حرف: 
SELECT Author‏ 



































FROM Authors 

WHERE Author LIKE "_ [i4] %' 

ولو أردت أن تبحث عن المؤلفين الذين تبدأ أسماؤهم بأحد الحروف 
المحصورة بين الفاء والياء وتنتهي بحرف السين» فاستخدم الصيغة: 

'س %[ف-ي] ' 
تعبّر عن أي حرف غير ذلك الموجود في القوسين (سواء من الحروف 
المذكورة صراحة أو من الحروف التي تقع في المجال المحدد).. 
لاختضار اذاهو نف اة اة 
مثال: استخدم الجملة التالية للحصول على جميع أسماء المؤلفين التي لا 
يكون ثالث حرف فيها ۸ أو 8 أو ©: 

SELECT Author 

FROM Authors 

WHERE Author LIKE "_[^ABC]%' 

ولو أردت أن تبحث عن السجلات التي لا تبدأ بأحد الحروف 
المحصورة بين 1 و 7 وتنتهي بالحرف 5, فاستخدم الصيغة: 

]ا 


ملحوظة: 

إذا أردت البحث في النص عن أي علامة من هذه العلامات الخاصّة» فضعها 
بين قوسين مضلعين.. فمثلاء يمكنك استخدام الصيغة '%[%]%50' للبحث عن 
النصّ "50%" في أي موضع من النص. 























المقارنة بنات تج | ستعلام: 
من الإمكانيّات التي تمنحها لك الفقرة ۴ WHER‏ قدرتك على مقارنة قيمة أحد 
الحقول» بقيمة أي حقل من جدول آخرء ناتج عن جملة 515115071 كاملة أخرى! 
انظر للمثال التالي» وفيه نحصل على كل الكتب التي ألفها (عباس العقاد) و(توفيق 
الحكيم): 
SELECT *‏ 
From Books‏ 
WHERE AuthorID = (SELECT ID‏ 
FROM Authors‏ 
'عباس العقاد' = WHERE Author‏ 
('توفيق الحكيم' = OR Author‏ 
حيث ثعيد 5818٣1‏ الفرعيّة حقلا به رقمي هذين المؤلفين» لتقوم جملة 
ELE)‏ الخارجيّة بإيجاد السجلات التي تحتوي على أي من هذين الرقمين في 
الحقل .AuthorID‏ 
لاحظ أنك تستطيع اختصار الجملة السابقة إلى ما يلي: 
SELECT Books.*‏ 
From Authors , Books‏ 
WHERE AuthorID = Authors.ID‏ 
'توفيق الحكيم' = OR Author‏ 'عباس العقاد' = AND Author‏ 





يمكنك استخدام بعض الدوال في تكوين شرط 1٤۸۴‏ ۰)۷ مثل دول أخذ جزء من 
النص SUBSTRING‏ و '1.117”1آ و R161‏ ودالة حذف المسافات الطرفية 
4 ودالة طول النص ..15N‏ والمثال التالي يعيد الناشرين الذين تنتهي 
أسماؤهم بالحرفين "ية": 

SELECT Publisher 
FROM Publishers 
WHERE (RIGHT (Publisher, 2) = )'ڍ'‎ 

أما المثال التالي فيعيد أطوال أسماء الناشرين: 
SELECT LEN(Publisher)‏ 
FROM Publishers‏ 


وضع اسم مستعار باستخدام الكلمة 45ل: 
رأينا من قبل كيف يمكن استخدام الكلمة 45, لوضع اسم مستعار للجدول.. مثلا: 
SELECT A.*, B.ID, B.Book‏ 
FROM Authors As A, Books As B‏ 
ويمكنك أيضا استخدام الكلمة ۸8 لوضع اسم مستعار للحقل.. مثال: 
[مؤلفه] Author AS‏ ,[اسم الكتاب] SELECT Book AS‏ 
FROM Books, Authors‏ 
WHERE AuthorID = Authors.ID‏ 
الآن ستظهر أسماء المؤلفين وكتبهم» ولكن عنواني العمودين سيكونان اسمين 
عربيّين هذه المرة. ٠‏ 
ومن الاستخدامات الطريفة للاسم المستعارء استخدامه لتسميّة أحد الحقول الناتجة 
عن دمج حقلين معا.. افترض أننا نريد عرض حقل يحتوي على اسم الكتاب متبوعا 
بشرطة متبوعة باسم المؤلف.. لفعل هذاء علينا تشبيك 2216ع002026 الحقلين» 
تماما كما نفعل مع المتغيّرات النصّيّة في لغات البرمجة العادية» مع منح الحقل 
الناتج اسما مستعارا باستخدام الكلمة كر كالتالي: 
]اسم الكتاب] SELECT Book + '_' + Author AS‏ 
FROM Books, Authors‏ 
WHERE AuthorID = Authors.ID‏ 


ملحوظة: 

عند تنفيذ الجملة السابقة في باني الاستعلام سيتم وضع التعبير +' '+ Book‏ 
Author‏ كحقل في قسم المعايير ©2826 0116113)؛: مع منحه الاسم المستعار 
"اسم اكاب ,هند عي الطريفة التي تف بها الحقول التدمتجلة في يناني 
الأ اكت ال اى تح يون القن فن ى خادة فار عة فى ارد 
«Column‏ وامنح هذا الحقل الجديد الاسم المستعار المناسب. 








وليست الحقول النصّيّة فقط هي ما نستطيع دمجه» حيث يمكننا أن نجرى عمليّات 
الجمع والطرح والضرب والقسمة على الحقول الرقميّة كما يحلو لنا. 











الكلمة 1007: 
يمكنك استخدام هذه الكلمة بعد 511101 مباشرة؛ وذلك إذا كان عدد السجلات 
الناتجة عن تنفيذ الاستعلام كبيراء بينما ينحصر اهتمامك في مجموعة قليلة منها 
فقط.. فمثلاء لكي تعرض أوّل خمس سجلات من أسماء الكتب ومؤلفيها استخدم 
الجملة التالية: 
SELECT TOP 5 Book, Author‏ 
FROM Books, Authors‏ 
WHERE AuthorID = Authors.ID‏ 
وإذا لم تكن تعرف بالضبط عدد السجلات المطلوبة» فيمكنك استخدام النسبة المئويّة 
PERCENT‏ كالتالي: 
SELECT TOP 5 PERCENT Book, Author‏ 
FROM Books, Authors‏ 
WHERE AuthorID = Authors.ID‏ 


الكلمة 'منفصل" :DISTINCT‏ 
استخدم هذه الكلمة لإزالة السجلات المكرّرة من ناتج الاستعلام.. فمثلاء لو عرضنا 
جدولا بأسماء الكتب بدون مؤلفيهاء فقد يتكرر اسم أحد الكتب أكثر من مرة 
(لمؤلفين مختلفين).. هنا يمكن تلافي هذا التكرار باستخدام الجملة التالية: 
SELECT DISTINCT Book‏ 
FROM Books‏ 


تشيرٌ القيمة 7711 في قاعدة البيانات» إلى أن الخانة لم توضع بها أي قيمة من 
أساميه.. لهذا تختلف الخانة التي بها نص فارغ "" عن الخانة التي ليس بها أي 
وعند تنفيذ الفقرة ۴ H٤ R‏ فإنها لا تسترجع أي خانة فارغة:» لأن القيمة 
N U11‏ تنتج 70156 بطريقة دائمة في أي عمليّة مقارنة.. هذا بالإضافة إلى أن 
دخول هذه القيمة في أي عمليّة حسابيّة يؤدتى إلى حدوث خطإ في البرنامج. 
لهذا يجب أن تعامل هذه القيمة بحذرء حيث يمكنك أن تختبر وجودها باستخدام أحد 
التعبيرين NULL‏ 19 أو NOT NULL‏ 9].. وكمثال» استخدم الاستعلام التالي 
للبحث عن أي خانة في الحقل 1101 تم تركها فارغة: 
SELECT * FROM Authors‏ 
WHERE Author IS NULL‏ 


لاحظ أنك تستطيع تلافي الكثير من احتمالات الخطأ الناتجة عن القيمة 7[11» 
بإزالة علامة الاختيار من العمود 15ل 411077 عند تصميم الحقول»ء بحيث لا 
يستطيع مدخل البيانات ترك خانة فارغة في هذا الحقل. 


فقرة الترتيب 8¥ +01+10101: 
يمكنك ترتيب السجلات الناتجة من الاستعلام تبعا لحقل أو أكثر.. وفي المثال التالي 
سنعرض أسماء الكتب ومؤلفيها مرتبة باسم الكتاب: 
SELECT Book, Author‏ 
FROM Books, Authors‏ 
ORDER BY Book‏ 
WHERE AuthorID = Authors.ID‏ 
ولكن لو كانت هناك كتب تحمل نفس الاسمء فكيف سيتمٌ ترتيبها؟ 
في هذه الحالة يمكنك أن تحذد حقل المؤلفين كمفتاح ثان للترتيب» بحيث لو تشابهت 
أسماء الكتب» يتم ترتيب الكتب المتشابهة على حسب أسماء مؤلفيها: 
SELECT Book, Author‏ 
FROM Books, Authors‏ 
ORDER BY Book, Author‏ 
WHERE AuthorID = Authors.ID‏ 
ويكون هذا الترتيب تصاعديًا في الوضع الافتراضي.. ولو أردت أن تغير طريقة 
الترتيب» فاستخدم الكلمة ‏ 1218150 بعد اسم أي حقل تريد ترتيبه تنازليّاء والكلمة 
50 بعد اسم الحقل الذي تريد ترتيبه تصاعديًا (وهي افتراضيّة ويمكن عدم 
كتابتها).. مثال: 
SELECT Book, Author‏ 
FROM Books, Authors‏ 
ORDER BY Book DESC, Author ASC‏ 
WHERE AuthorID = Authors.ID‏ 


ملحوظة: 

لوضع كيفيّة الترتيب في باني الاستعلام» حدد الحقل الذي تريد أن يتم الترتيب 
على أساسه في قسم المخطط عورجحم7 Diagram‏ واضغطه بزل الفأرة الأيمن» 
ومن القائمة الموضعيّة اضغط الأمر ع01ءع850 5016 إذا كنت تريد الترتيب 
تصاعديّاء أو الأمر ع010لمءء12»5 501 إذا كنت تريد الترتيب تنازليًا.. ستجد 
أن أيقونة تمثل نوع الترتيب قد ظهرت بجوار اسم الحقل.. ولو أردت إزالة 
الترتيب» فاضغط نفس الأمر من القائمة الموضعيّة مرّة أخرى.. ويمكنك فعل 
ذلك مع أكثر من حقل ومن أي جدول» حيث ستظهر كلها في جملة .501 
بالترتيب الذي أضفتها به. 

كما يمكنك اختيار نوع الترتيب بطريقة أخرىء وذلك باستخدام قسم المعايير 
Pane‏ 11110 )» حيث يمكنك استخدام القائمة المنسدلة في العمود الذي يحمل 
العنوان 15/06 5014 لتغيير طريقة ترتيب أي حقل. 

وإذا أردت استخدام أكثر من حقل للترتيب على أساسهاء فعليك استخدام العمود 
Order‏ 5011 للتحكم في أولوية هذه الحقول في عملية الترتيب» فالحقل الذي 
سيتم الترتيب على أساسه أولا أعطه الرقم ١ء‏ والحقل الذي سيتم الترتيب على 
أساسه في حالة تشابه قيم الحقل الأول أعطه الرقم ۲» وهكذا. 





:Aggregate functions دوال التجميع‎ 

تمنحك ,5001 بعض الدوال الجاهزة لحساب بعض النتائج.. لاحظ ما يلي: 

- هذه الدوال تقبل معاملا واحدا فقطء هو أحد أعمدة الجدول» أو أي عمود جديد 
ناتج عن إجراء عمليّة حسابيّة (كالجمع والطرح والضرب والقسمة) على واحد 
أو أكثر من الأعمدةء أو أي عمود ناتج من جملة S1٤٣1‏ فرعيّة. 

- هذه الدوال تعيد قيمة واحدة فقط (رقما منفردا).. أي أن الناتج منها هو عمود 
يحتوي على خانة واحدة فقط.. ولو كنت ستعرض هذه النتيجة» فاستخدم التعبير 
5 لمنح هذا العمود الجديد اسما مناسباء وإلا فإن ,501 ستمنحه اسما افتراضيًا 


من لديها. 
- لا مانع من استخدام الفقرة :77/111511 لتحديد السجلات التي ستتمٌ العمليّة 
الحسابية عليها. 


و هذه الدوال هي: 














العدد :COUNT‏ 
تحسب عدد الخانات في العمود المرسل كمعامل. . ويمكن تطبيقها على أي 
نوع من البيانات.. والجملة التالية تحسب عدد الكتب التي ألفها توفيق الحكيم: 
[عدد الكتب المتاحة] SELECT COUNT(Book) AS‏ 
FROM Books, Authors‏ 
'توفيق الحكيم' = WHERE Author‏ 
AND AuthorID = Authors.ID‏ 
لاحظ أن الحقول التي تحتوي على القيمة N01‏ لا يتمّ عذها ضمن 
السجلات.. ولو أردت أن تفعل العكس» فعليك أن ترسل الرمز (*) كمعامل 
لهذه الدالة» حتى تأخذ هذه السجلات في اعتبارها: 
[عدد المؤلفين] 45 SELECT COUNT(*)‏ 
From Authors‏ 


العدد الكبير 00101171_13160: 

مماثلة للدالة 0017111 في كل شيء. إلا أن ناتج الدالة 0017117 يكون 
عددا صحيحا من النوع مء بينما ناتج الدالة 00177171:_18103) يكون عددا 
صحيحا كبيرا 126ع61» لهذا عليك استخدامها عند التعامل مع جداول ضخمة 
يتجاوز عدد سجلاتها ۲ مليار سجل! 


المجموع 51[1/1: 
تحسب مجموع الخانات في العمود المرسل كمعامل.. ويمكن تطبيقها على 
الأعمدة الرقميّة فقط, 
مثال: الجملة التالية تحسب مجموع النسخ المتاحة من جميع الكتب: 
[إجمالي النسخ] SELECT SUM(Copies_No) AS‏ 
From Books‏ 


المتوسط ۷6 ۸: 
تحسب المتوسط الحسابي (مجموع العناصر + عددها) لخانات العمود المرسل 
كمعامل.. ويمكن تطبيقها على الأعمدة الرقميّة فقط.. والمثال التالي يحسب 
متوسط عدد نسخ الكتب: 1 
[متوسط النسخ] SELECT AVG(Copies_No) AS‏ 
From Books‏ 


:M11٨ الأصغر‎ 


تحسب أصغر قيمة في العمود المرسل كمعامل.. ويمكن تطبيقها على الأرقام 
والنصوصء وفي حالة النصوص ستعيد أصغر نص في الترتيب الأبجدي. 


الأكبر ×۸ 1: 
تحسب أكبر قيمة في العمود المرسل كمعامل.. ويمكن تطبيقها على الأرقام 
والنصوصض».وفي حالة النصوص ستعيد أكين نص في الثرتيب: الأبجدئ: 


المجموع التأكيدي :©6066 111:0151711_4©: 
هذه الدالة خاصية ب ,7-901 فقط ولا تستطيع استخدامها مع قواعد بيانات 
أكسيس.. وهي تجري عملية حسابية على جميع قيم العمود» وتعيد المجموع 
التاكيدي رررن5 عاءءط0)» وهو قيمة يمكنك استخدامها للتاكد من أن خانات 
العمود لم يحدث بها تغيير فطالما ظلت ثابتة فهذا معناه أن قيم العمود لم 
تتغير.. هذا أفضل من حفظ جميع قيم العمود القديمة» ثم التأكد من أن كلا منها 
8 تتغير على حدة. . لاحظ أن هناك احتمالا صغيرا في أن تتغير بعض قيم 
العموة لكن تظل هذه الدالة تعطي نفس الناتج.. لاحظ أيضا أن هذه الدالة لا 
تهتم بكيفية ترتيب العمود.. مثال: 
SELECT CHECKSUM _ AGG(Copies_No)‏ 
FROM Books‏ 
وتوجد دالة أخرى في .1-501 اسمها CHECKSUM‏ ولكنها ليست دالة 
تجميع» فهي تعيد عمودا جديدا وليس قيمة واحدة فقط.. وتنتج كل خانة في 
العمود العائد من حساب قيمة مختلطة ع11[ج7؟ 11355 لكل خانة في العمود 
الأصلي. 


التغير الإحصائي :۷AR‏ 

تحسب التغير الإحصائي ععمصهi٣ه۷‏ 56351021 للقيم الموجودة في 
العمود.. لو لم تدرس مادة الإحصاء من قبل» فلا تشغل بالك بهذه الدالة وكل 
الدوال التالية! 


التغير الإحصائي السكاني R۲‏ ۷۸: 
تحسب التغير الإحصائي السكاني Statistical variance for population‏ 
للقيم الموجودة في العمود. 


7# الانحراف الإحصائي المعياري ۷٤5۲5؟:‏ 


تحسب الانحراف الإحصائي المعياري Statistical Standard Deviation‏ 
للقيم الموجودة في العمود. 


> الانحراف الإحصائي المعياري السكاني 5711(21:579: 
تحس ب الانحراف الإحصسائي المعياري السكاني 


Standard Deviation for Population‏ 50521 لقيم العمود. 


ويمكنك استخدام القيم المعادة من هذه الدوال في شروط الفقرة WHERE‏ .. 
والمثال التالي يريك كيف نحسب عدد الكتب التي ألفها أوّل مؤلف في الترتيب 
الأبجدي: 
[عدد كتب المؤلف الأول] SELECT COUNT(B0ook) AS‏ 
FROM Books, Authors‏ 
WHERE AuthorID = Authors.ID‏ 
AND Author = (SELECT MIN(Author)‏ 
From Authors)‏ 
حيث استخدمنا جملة 88180٧1‏ فرعيّة لتعيد ناتج الدالة 7/4117 في شرط الفقرة 
117. على كل حال» هناك صيغة ثانية للمثال الأخيرء باستخدام الربط 
الداخلي 100117 181211112 الذي سنتعرّف عليه لاحقا. 
ولكن ماذا لو أردت أن تطبّق هذه الدوال على حقل به قيم مكرّرة» وأردت ألا تأخذ 
التكرار في اعتبارك؟ 
في هذه الحالة يجب أن تستخدم الكلمة 10197117107 للحصول على حقل ليس به 
أي تكرار. . وتوضع هذه الكلمة قبل اسم الحقل مباشرة (داخل قوس الدالة).. 
والمثال التالي يريك كيف نحسب عدد المؤلفين بحساب عدد خانات الحقل 
052ا في جدول الكتب بدون تكرار: 
[عدد المؤلفين] SELECT COUNT (DISTINCT AuthorID) AS‏ 
From Books‏ 
ملحوظة: 
لاستخدام دوال التجميع في باني الاستعلام» اضغط اسم الحقل في قسم المعايير 
Criteria Pane‏ بزر د الفأرة الأيمن» ومن القائمة الموضعيّة اضغط الأمر Add‏ 
By‏ م012011.. سيظهر عمود جديد في جدول الحقول اسمه 1857 0upإG»›‏ 
وسيكون مكتوبا فيه مبديا النص ر8 م61011.. اضغط زر إسدال القائمة» حيث 
ستجد بها أسماء دوال التجميع التي يمكنك استخدامها.. اختر منها ما تريد 
لتطبيقه على هذا الحقل. 
8 السجلات باستخدام الد :GROUP BY‏ 
رأينا كيف نجري بعض العمليّات الحسابيّة باستخدام دوال التجميع.. ولكن ماذا لو 
أردنا مثلا أن نحصل على سجل يحتوي على عدد الكتب التي ألفها كل مؤلف؟ 
في هذه الحالة لن تسعفنا التعبيرات التي تعلمناها حتى الآن. . 








١ 











هنا تبرز أهمّية التعبير 8 61901[7)» الذي يقوم بتقسيم سجلات الجدول إلى 
(كرقم المؤلف مثلا)» ومن ثم يتم تطبيق دوال التجميع على كل مجموعة فرعية 
بمفردهاء وبهذا يكون ناتج دوال التجميع عمودا يحتوي على مجموعة من 
الصفوف» وليس صفا واحدا كما ألفنا من قبل.. هذه هي الجملة التي تحسب عدد 


كتب كل مؤلف: 
[عدد الكتب] SELECT AuthorID, COUNT(AuthorID) AS‏ 
FROM Books‏ 
GROUP BY AuthorID‏ 


ORDER BY [عدد الكتب]‎ 


لاحظ قدرتنا على استخدام الاسم المستعار للعمود الناتج في باقي جملة 501. 

ولكن.. الجدول الناتج من الاستعلام السابق يحتوي على أرقام المؤلفين وليس 
أسماءهم.. لهذا لا ضير من استخدام الفقرة ١ء۷1‏ للربط بين الجدولين كالتالي: 

SELECT Author, COUNT(AuthorID) AS [عدد الكتب]‎ 

FROM Authors, Books 

Where AuthorID = Authors.ID 

GROUP BY Author 

ORDER BY [عدد الكتب]‎ 


لاحظ أننا قمنا بعملية التجميع في الجملة الأخيرة باستخدام الحقل إ0 طا ن۸.. السبب 
في هذاء هو أن هناك قيدا صارما على الحقول المذكورة في المقطع »S٤ 1٤٣1‏ 
وهو أنها جميعا يجب أن تظهر إما في المقطع 8۷ 6۸01۴ وإما في المقطع 
..0RD ER BY‏ لهذا لو تركنا التجميع على الحقل (8110111, فستعترض 
سيكويل سيرفر على ظهور اسم الحقل 1101 في المقطع !SE L٤٣۲‏ 


ملحوظة: 

لاستخدام الفقرة Group By‏ في باني الاستعلام» اضغط اسم الحقل في قسم 
المعايير عمnرPa Criteria‏ بزر الفأرة الأيمن» ومن القائمة الموضعيّة اضغط 
الأمر ر8 م0101 4ل۸.. سيظهر عمود جديد في جدول الحقول اسمه upهاG‏ 
87» وسيكون مكتوبا فيه مبديا النص ر8 م62011).. هذا معناه تجميع القيم 
المتشابهة لهذا الحقل. 

ولو أردت إضافة دالة تجميع مع الفقرة 1337 1011© لنفس الحقل» فكرر اسم 
الحقل مرة أخرى في قسم المعايير بضغط صف فارغ بالفأرة واختيار اسم 
العمود من القائمة المنسدلة الموجودة في العمود 0011» وبهذا تستطيع أن 
تضيف إلى هذا الحقل دالة التجميع التي تريدها. 





استخدام الفقرة :H ۸ V1×NG‏ 
ماذا لو أردنا عرض أسماء المؤلفين الذين تزيد كتبهم عن كتاب واحد؟ 
في هذه الحالة يمكننا استخدام الفقرة ۷16 1۸[› وهي فقرة شرطية تسمح 
باستخدام دوال التجميع في الشرط كالتالي: 
[عدد الكتب] SELECT Author, COUNT(Author1D) AS‏ 
FROM Authors, Books‏ 
Where AuthorID = Authors.ID‏ 
GROUP BY Authors.Author‏ 
HAVING COUNT(AuthorID) > 1‏ 
[عدد الكتب] ORDER BY‏ 


ملحوظة: 

لبناء الفقرة [N6‏ 4[ السابقة في باني الاستعلام.. اذهب إلى الخانة م1011 
13 الخاصنة بالعمود 5615ا في قم المعايير» ومين القائمنة المفسكلة اخثز 
الدالة رن:00)» ثم انتقل إلى الخانة ع11[1 المجاورة» واكتب فيها الشرط 1<.. 
هذا معناه أن أي شرط تكتبه في الخانة +7116 أثناء ظهور العمود Group By‏ 
سيظهر كشرط في الفقرة ع813910.. لكن لو كنت تريد استخدامه كشرط في 
الفقرة ١۲ء۰0۷1‏ فأسدل القائمة المنسدلة في الخانة و8 610117 واختر منها 
العنصر Where‏ . 





























عمليات الربط 10115 .5001: 
تحدّد عمليّات ربط الجداول 10105 كيفيّة استعادة البيانات من الجداول التي بينها 
علاقات.. وهناك خمسة أنواع من عمليّات الربط: ۰ 
-١‏ الربط المتقاطع ەل 01055. 
۲- الربط الأيسر مزه[ 16©.آ. 
؟- الربط الأيمن 1010 1!1214. 
-٤‏ الربط الكامل نزح[ 1"1111. 
5- الربط الداخلي 010[ 0061]. 
دعنا نتعرف على هذه الانواع. 


الربط المتقاطع يرزول 2055'): 
لقد تعرفنا على هذا النوع من الربط سابقاء فهو ينتج تلقائيا عند عرض حقلين من 
جدولين مختلفين بدون ذكر أي طريقة لربطهما معا.. في هذه الحالةء يتم ما يشبه 
عملية الضرب» حيث يتم تكوين أزواج تبادلية من الحقلين» بحيث تظهر كل خانة 
من الجدول الأول مع كل خانة من الجدول الثاني في هذه الأزواج» وبهذا يكون عدد 
السجلات الناتجة = عدد خانات الحقل الأول × عدد خانات الحقل الثاني.. مثال: 
SELECT Author, Book‏ 
FROM Authors, Books‏ 
عند تنفيذ هذا الاستعلام» سيظهر ناتج شبيه بما يلي (سنفترض أن هناك مؤلفين 
اثنين فقط على سبيل الاختصار): 








Author Book 
الطعام لكل فم توفيق الحكيم‎ 
شهرزاد توفيق الحكيم‎ 
مهنتي القتل توفيق الحكيم‎ 
الاحتلال توفيق الحكيم‎ 
الطعام لكل فم نبيل فاروق‎ 
شهرزاد نبيل فاروق‎ 
مهنتي القتل نبيل فاروق‎ 
الاحتلال نبيل فاروق‎ 





طبعا هذا ناتج عجيب وليس عمليا هناء ولكنه قد يبدو عمليا في بعض التطبيقات 
الرياضية التي تحتاج فيها إلى الحصول على تباديل قيمتين أو أكثر. 


YY 
































وتوجد فقرة خاصة بهذا النوع من الربط وهي الفقرة 701171 21055» ولو 
كتبت الاستعلام السابق في باني الاستعلام» فسيتم تحويله تلقائيا إلى الصيغة التالية: 

SELECT Author, Book 

FROM Authors CROSS JOIN Books 


ملحوظة: 

لإنشاء الجملة السابقة باستخدام باني الاستعادم؛ حذد الحقل )800 من جدول 
الكتب» والحقل 11101 من جدول المؤلفين» ثمّ اضغط بزرٌ الفأرة الأيمن على 
الخط الواصل بين الجدولين» ومن القائمة الموضعيّة اضغط الأمر: ع[ 
لحذف الربط بين الجدولين.. هذا سيجعل الربط بينهما تقاطعيا!.. لاحظ أن حذف 
هد | :العم ل ححدت اة المو جود ة فين الحدو لي ب ك فقط يو أل على لفن 
بناء الاستعلام.. ولإعادة رسم الخط مرة أخرىء اسحب الحقل «(4:11015.11/ 
وأسقطه على الحقل .Books.Autho1ID‏ 








الربط الأيسر رامل )1,©1: 
تعررج هذه الحدانة كل ماقف امازل gaa‏ يداب المديكة ادمع 
بعض سجلات الجدول الأيمن» التي تحقق شرط الربط (الذي يأتي بعد الكلمة 0[11). 
ويمكننا أن نعرض كل أسماء المؤلفين وأسماء الكتب الخاصة بكل منهم» كالتالي: 
SELECT Book, Author‏ 
FROM Authors LEFT JOIN Books‏ 
ON AuthorID = Authors.ID‏ 
ولكي تشعر بوجود اختلاف عن ناتج الجملة ۴ »WHER‏ يجب أن يكون هناك 
بعض المؤلفين الذين لا توجد لهم كتب مناظرة في جدول الكتب» فاستخدام الربط 
الأنسسن سو صق اة كل المؤلفين مع ترك خانة الكتاب فارغة 011 للمؤلف 
الذي لا توجد له كتب.. لكن دون عرض الكتب التي لا يناظرها مؤلفون.. بينما 
الجملة ۴ WHER‏ لا تعرض إلا المؤلفين الذي لهم كتب. 
ملحوظة: 
لإنشاء الجملة السابقة باستخدام باني ا حذد الحقل )800 من جدول 
الكتب» والحقل 1101م من جدول المؤلفين» ثم م اضغط بزر الفأرة الأيمن على 
علامة الربط في منتصف الخط الواصل بين الجدولين» ومن القائمة الموضعيّة 
اضغط الأمر: ..Select A11 Rows From Authors‏ هذا هو كل شيء! 








الربط الأيمن زم[ Right‏ : 
مماثل للربط الأيسرء إلا إن كل سجلات الجدول الأيمن يتمّ عرضها بالكامل» مع 
عرض سجلات الجدول الأيسر التي تحقق شرط الربط.. مثال: 
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SELECT Book, Author 
FROM Authors RIGHT JOIN Books 
ON AuthorID = Authors.ID 
ولكي تشعر بتأثير الربط الأيمن» يجب أن يكون هناك بعض الكتب التي لا يوجد‎ 
لها مؤلف في جدول المؤلفين» فاستخدام الربط الأيمن سيعرض أسماء كل الكتب»‎ 
.NULL والكتاب الذي ليس له مؤلف سيتم ترك خانة المؤلف المناظرة له فارغة‎ 
تذكر أننا عندما أنشأنا الحقل (8110111, أزلنا علامة الاختيار من الخاصيّة‎ 
لهذا لن يمكنك ترك خانة رقم المؤلف فارغة.. ويمكنك تغيير قيمة‎ 811077 5 
هذه الخاصيّة وتجرّبة إدخال كتاب بدون مؤلفء لترى تأثير عمليّة الربط الأيمن.‎ 
ملحوظة:‎ 
لإنشاء الجملة السابقة باستخدام باني الاستعادم؛ حذد الحقل )مم8 من جدول‎ 
الكتب» والحقل 0۲ ط۸ من جدول المؤلفين» ثمّ اضغط بزرٌ الفأرة الأيمن على‎ 
علامة الربط في منتصف الخط الواصل بينَ الجدولين» ومن القائمة الموضعيّة‎ 
هذا هو كل شيء!‎ ..Select 311 Rows From Books اضغط الأمر:‎ 








الربط الكامل «رزمل ااF۴u:‏ 
هذا النوع هو مزيج من الربط الأيمن والأيسرء وفيه يتم عرض كل بيانات 
الجدولين التي تحقق شرط الربط.. مثال: 
SELECT Book, Author‏ 
FROM Authors FULL JOIN Books‏ 
ON AuthorID = Authors.ID‏ 
ولكي تشعر بتأثير الربط الكامل» يجب أن يكون هناك بعض المؤلفين الذين لا توجد 
لهم كتب» وبعض الكتب التي لا يوجد لها مؤلف» حيث سيتمٌ عرض أسماء هؤلاء 
المؤلفين وهذه الكتب» مع ترك الخانة المناظرة فارغة .NULL‏ 
ملحوظة: 
لإنشاء الجملة السابقة باستخدام باني الاستعلام» اتبع نفس الخطوات التي اتبعناها 
في إنشاء الربط الأيسرء ولكن اختر كلا الاختيارين Select All Rows‏ 
«From Books‏ و Rows From Authors‏ 11آى ectاSe..‏ لاحظ تغير شكل 
الأيقونة المجاورة عند اختيار أي من هذين الخيارين.. ولإلغاء أي اختيار 
اضغطه مرة أخرى. 








الربط الداخلي :Inner Join‏ 
هذه العمليّة مماثلة للفقرة 1٤ R۴‏ ۷› حيث يتم عرض السجلات المتوافقة فقط من 
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SELECT Book, Author 
FROM Authors INNER JOIN Books 
ON AuthorID = Authors.ID 


ملحوظة- 

لإنشاء الجملة السابقة باستخدام باني الاستعلام» حذد الحقل )مم8 من جدول 
الكتب» والحقل طا ں۸ من جدول المؤلفين.. هذا كل شيء! 

ولوكنت اخترت الربط الأيسر» أو الربط الأيمن» فاضغط رمز العلاقة بزر 
الفأرة الأيمن» ومن القائمة الموضعية أعد ضغط الأمر Select All Rows‏ 
«From Books‏ أو Select A1] Rows From‏ لإزالة اختياره. 


لاحظ أن الربط الأيسر والربط الأيمن والربط الكامل تعتبر جميعا أنواعا من الربط 
الخارجي ز10 0161.. لهذا يمكنك أن تضيف الكلمة 001۴8 بعد كل من 
RIGHT JOIN LEFT JOIN‏ و FLL JOIN‏ »وهو مايفعله باني 
الاستعلام تلقائياء فهو يضيف الكلمة 01۴۸ حتى لو لم تكتبها أنت. 








استعلامات الأداء :Action Queries‏ 
يعتبر هذا النوع من الاستعلامات أبسط من استعلامات التحديد» فهو لا يقوم 
باسترجاع أي سجلات. . ولكنه في المقابل يغير بعض بيانات الجدول» سواء 

بتحديث قيم السجلات أو بإضافة سجلات جديدة أو بحذف بعض السجلات 
الموجودة. 
ويعيد استعلام الأداء عدد السجلات التي تأثرت بالعملية (وليس السجلات نفسها). 


ملحوظة: 

لن تستطيع تجربة هذه الاستعلامات في نافذة باني الاستعلام الخاصة بالعروض 
«View‏ لأنها كما ذكرنا تستخدم استعلامات التحديد لعرض جزء من جدول أو 
أكثر.. وبدلا من هذاء يمكنك ضغط العنصر 7716778 في متصفح الخوادم 
Explorer‏ :561761 بزر الفأرة الأيمن وضغط الأمر New Query‏ لفتح نافذة 
باني استعلام خاصة باستعلام عام.. في هذه الحالة يمكنك تجربة أمثلة 
استعلامات الأداء بلصقها في جزء الاستعلام 241717 ,501 في هذه النافذةء 
وضغط الأمر ,5001 160116 من القائمة الموضعية. 

حذف الصفوف باستخدام الأمر :DELETE‏ 

تحذف هذه الجملة أي عدد تريده من الصفوف تبعا للشرط الذي تحدّده في المقطع 
118115.,. والجملة التالية تريك كيف يمكن حذف كل الكتب نفدت: 

DELETE FROM Books 
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WHERE Copies_No = 0‏ 
ملحوظة: 
لبناء أمر الحذف السابق في باني الاستعلام» أضف الجدول 80015 إلى قسم 
المخطط واضغط بزر الفأرة الأيمن في أي موضع خال من قسم المخطط ومن 
القائمة الموضعية اضغط 6م157 013286 ومن القائمة الفرعية اضغط الأمر 
11 . ستجد أن جملة ,501 المكتوبة قد تحولت إلى 5٤1۴٤1‏ بدلا من 
.SELECT‏ 
استخدم قسم المعايير عمج۴ 0116212 لإضافة اسم الحقل 1[0_و16م00» وضع 
في العمود مرع]111 القيمة: 
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والجملة التالية تحذف كل الكتب التي كتبها (عباس العقاد): 
DELETE FROM Books‏ 
WHERE AuthorID = (SELECT ID‏ 
FROM Authors‏ 
(' عباس العقاد' = WHERE Author‏ 
طبعا لاحظت استخدامنا لاستعلام التحديد في جملة الشرط.. هذه الإمكانيّة تمنحك 
قدرات بلا حدود» لحذف السجلات التى تنطبق عليها المواصفات التى تحدّدها. 
وهناك طريقة أخرى لأداء نفس العمليةء وذلك باستخدام الفقرة :70 لاختيار 
الجداول ووضع شروط الربط بينها باستخدام الفقرة :777115191 أو طرق الربط 
المختلفة 7015.. دعنا نكتب المثال السابق باستخدام الربط الداخلي: 
DELETE FROM Books‏ 
FROM Books INNER JOIN‏ 
Authors ON Books.AuthorID = Authors.ID‏ 
("عباس العقاد' = WHERE (Authors.Author‏ 
وهو نفس ما يمكنك فعله بالجملة 1771117117 كالتالي: 
DELETE FROM Books‏ 
FROM Books, Authors‏ 
WHERE AuthorID = Authors.I[D AND‏ 
"عباس العقاد' = Authors.Author‏ 
ملحوظة: 
لبناء أمر الحذف السابق في باني الاستعلام» اضغط بزر الفأرة الأيمن في أي 
موضع خال من قسم المخططء ومن القائمة الموضعية اضغط Change Type‏ 
ومن القائمة الفرعية اضغط الأمر 6]ء1(6[1. 
أضف الجدول 80015 أولا (ليتم الحذف منه) ثم أضف الجدول Authors‏ 
ليقوم باني الاستعلام بتكوين فقرة الربط بينهما. 
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وفي قسم المعايير Criteria Pane‏ اختر اسم الحقل Authors.Author‏ من 
العمود جزرون[0") وفي العمود ,11166 الخاص بهذا الحقل ضع الشرط: 
'عباس العقادا! = 








إدراج سجلات جديدة باستخدام الأمر :1NSERT‏ 
يمكنك إضافة سجلات جديدة إلى الجدول» باستخدام أمر الإدراج '1721511121 على 
الصيغة التالية: 
(قيم الحقول) ۷۸11٤8‏ (أسماء الحقول) اسم الجدول INSERT [NTO‏ 
حيث ستضاف القيم إلى الحقول تبعا لترتيب كتابة أسمائها.. ويمكن ألا تكتب كل 
أسماء الحقول» وفى هذه الحالة ستترك الخانات المناظرة للحقول فارغة.. ويجب أن 
يكون عدد القيم المرسلة مساويا لعدد أسماء الحقول المكتوبة.. والمثال التالي 
يضيف سجلا جديدا إلى جدول المؤلفين: 
INSERT INTO Authors (Author, CountryID, About)‏ 
(اشاعر مصري معاصر' ,21 ,'فاروق جويدة') ١74117105‏ 
لاحظ أننا لم نرسل قيمة إلى الحقل 15 لأنه ترقيم تلقائي» ولن يقبل منك أي قيمة.. 
كما أننا لم نرسل قيمة حقل رقم الهاتف» لأننا صممناه بحيث يقبل القيمة الفارغة 
N1‏ ولا مانع من إرسال قيمة له لو أردت.. لاحظ أيضا أن الرقم ۲١‏ هو رقم 
مصر في جدول الدول. 
وهناك تسهيل آخرء يتيح لك إدخال قيم كل الحقول دون أن تكتب أسماءهاء لكن في 
هذه الحالة عليك أن تكتب القيم مرتبة تبعا لترتيب الحقول الأصلي في الجدولء 
وذلك على الصيغة التالية: 
(قيم الحقول) 5٤ا‏ ۷۸ اسم الجدول INSERT INTO‏ 
فمثلا: لإضافة حقل جديد إلى جدول الكتب» استخدم الجملة التالية: 
INSERT INTO Books‏ 
(1000 ,2 ,3 ,'1/8/2000' ,7 ,6 ,14 ,'كانت لنا أوطان') VALUES‏ 
لاحظ أننا لم نضع قيمة للحقل 1D‏ لأنه يولد تلقائيّاء لهذا ستوضع القيم بالترتيب في 
الحقول التالية لهذا الحقل.. لكن المشكلة أنك لو لصقت الجملة السابقة في باني 
الاستعلام؛ فسيضيف أسماء الحقول تلقائيا إليها» ومن ضمنها الحقل 7]» لهذا عليك 
أن تحذفه وإلا حدث خطأ عند تنفيذ الاستعلام. 
لاحظ أيضا ضرورة وضع التاريخ بين العلامتين ' ' عند كتابة جمل .501» تماما 
كما نفعل مع النصوص.. كما أنك تستطيع استخدام الكلمة N01‏ كقيمة: إذا 
أردت ترك الخانة فارغة:؛ وإذا كانت الخانة تحتوي على بيانات ثنائية 
(كالصورة عع103) فأرسل إليها القيمة 0×0 وهي تعادل العدم 1ا اN.‏ 


ملحوظة: 
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لبناء أمر الإدراج في باني الاستعلام» أضف الجدول الذي ستقوم بالإدراج فيه 
إلى قسم المخططء واضغط بزر الفأرة الأيمن في أي موضع خال من قسم 
المخططء ومن القائمة الموضعية اضغط Change Type‏ ومن القائمة الفرعية 
اضغط الأمر 17210065 105616.. ستجد أن جملة ,501 المكتوبة قد تحولت إلى 
518117 بدلا من »SE1 ٤٣1‏ وستكون على هذه الصورة: 

INSERT INTO اسم الجدول‎ ) ( 

VALUES )( 

اختر أسماء الحقول التي تريد الإدراج فيها بوضع علامة الاختيار بجوارها في 
مخطط الجدولء لتظهر أسماؤها في جملة 501 داخل القوسين الفارغين التاليين 
لاسم الجدول.. بعد هذا عليك أن تضيف القيم بكتابتها في العمود New Value‏ 
في قسم المعايير عمهة52 113ع01): حيث ستكتب القيمة الجديدة في الخانة 
المجاورة لاسم كل حقل. 
ولو أردت العودة إلى استخدام الأمر »S8E1 8٣٧1‏ فاضغط بزر الفأرة الأيمن في 
أي موضع خال من قسم المخططء ومن القائمة الموضعية اضغط Change‏ 
6م190 ومن القائمة الفرعية اضغط الأمر )نه561. 





ويتيح لك الأمر 1 [NSR‏ نسخ مجموعة من السجلات من جدول إلى آخرء بشرط 
أن يكون لحقولهما نفس نوع البيانات» وذلك باستبدال الفقرة 7781]71:5 بالجملة 
.SELECT‏ 
افترض أن عندنا جدولا اسمه 190015م1مع1 مماثلا في تركيبه لجدول الكتب» 
ونريد أن نضع فيه بعض الكتب مؤقتا لأيَ سبب.. في هذه الحالة يمكن أن ننسخ فيه 
كتب (توفيق الحكيم) بالجملة التالية: 
INSERT INTO TempBooks‏ 
SELECT Books.*‏ 
FROM Authors, Books‏ 
AND AuthorID = Authors.ID‏ 'توفيق الحكيم' = WHERE Author‏ 
ملحوظة: 
لبناء الأمر الأخير في باني الاستعلام» أضف الجدولين Authors‏ و Books‏ 
إلى قسم المخطط وحدد كل الحقول من جدول الکتب› وحدد الحقل 1101م من 
جدول المؤلفين» وفي قسم المعايير عه 0116113 أزل علامة الاختيار من 
العمود 116م011) في صف الحقل 101 لكي لا يظهر في النتائج» وفي الخانة 
161 الخاصة بهذا الحقل أضف الشرط: ( 'توفيق الحكيم' = ) 
الآن لديك جملة التحديد 5115001 التي تحصل على النتائج التي تريد إدراجها 
في الجدول 10015مدطء1.. كل ما عليك فعله الآن» هو الضغط بزر الفأرة 
الأيمن في أي موضع خال من قسم المخطط ومن القائمة الموضعية اضغط 
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Change Type‏ ومن القائمةالفر عيةاضغطالأمر 
15 105616.. ستظهر لك نافذة تتيح لك اختيار الجدول الذي تريد إدراج 
النتائج فيه.. اختر الجدول 76130190015 وأغلق النافذة.. الآن ستجد جملة 
الإدراج كاملة في قسم الاستعلام !SQL Pane‏ 








. السجلات ١‏ دة باستخدام الأمر (5۸1٤‏ ][: 
لتغيير قيم بعض - أو كل سجلات أحد الجداول» استخدم الجملة 1121(4117]» التي 


لها الصيغة التالية: 

اسم الجدول UPDATE‏ 
........ بالقيمة؟ = الحقل؟ ,القيمة١‏ = الحقل١‏ '5151 
شرط WHERE‏ 

مثال: الجملة التالية تغير اسم المؤلف (نبيل فاروق) إلى (نبيل فاروق رمضان): 
UPDATE Authors‏ 
'نبيل فاروق رمضان' = SET Author‏ 
'نبيل فاروق' = WHERE Author‏ 

ملحوظة: 


لبناء الأمر الأخير في باني الاستعلام؛ أضف الجدول 8110015 إلى قسم 
المخططء وحدد الحقل .Author‏ 

اضغط بزر الفأرة الأيمن في أي موضع خال من قسم المخطط ومن القائمة 
الموضعية اضغط Change Type‏ ومن القائمة الفرعية اضغط الأمر 
pate‏ » وفي قسم المعايير عمه2 0116118 أضف الشرط التالي في الخانة 
ع1 الخاصة بالحقل 0١‏ طاں۸: ('نبیل فاروق' = 

وفي العمود 17216 New‏ السابق للعمود ه1711 اكتب: 'نبيل فاروق رمضان' 
الآن ستجد الأمر 0۲50۸1۴ مكتوبا في قسم .501 كاملا. 


التحرير المتتابع للسجلات« باستخدام الأمر :UPDATE .WR1TE‏ 
عند التعامل مع أعمدة تحتوي على بيانات من النوع 2زء) أو غ26 أو 11386 في 
سيكيويل سيرفر ٠۲٠٠۰‏ كانت تواجهنا مشكلة خطيرة» وهي كيفية إرسال كم ضخم 
من البيانات من العميل إلى الخادم لحفظه في هذه الأعمدة.. افرض أنك تريد وضع 

صورة حجمها ٠١‏ ميجا في خانة من النوع 6ع1012 بالاستعلام التالي: 

UPDATE Publishers 
SET Logo = @Logo 
WHERE ID =1 
حيث 0ع٥.آ@ هو معامل من النوع عه يحمل بيانات الصورة.. لو حاولت‎ 
تنفيذ هذا الاستعلام» فسيستغرق إرسال الصورة إلى الخادم وقتا ملموسا‎ 
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(تبعا لسرعة الاتصال» وحجم الضغط على الخادم في تلك اللحظة)» وقد يتعطل 
برنامجك عن الاستجابة» وقد ينفد وقت الانتظار {uا0عم]1‏ قبل إتمام العملية. 
ويمكنك أن تجرب الاستعلام السابق بضغط الزر 1.080 800 في المشروع 
8 1. جرب اختيار صورة حجمها كبير لترى تأثير هذا. 
وللأسف» لا يفيدك استخدام استعلام كالتالي: 
UPDATE Publishers‏ 
SET Logo = Logo + @Logo‏ 
WHERE ID =1‏ 
هذا الاستعلام يحاول إضافة جزء من بيانات الصورة موضوع في المعامل 
220 إلى البيانات الموجودة فعليا في عمود الصورة .Logo‏ . لكن للأسف» 
سيؤدي هذا إلى حدوث خطأء لأن سيكويل سيرفر لا يعرف كيف يجمع بيانات من 
النوع عع 2مم1آ ! 
ولحل هذه المشكلةء قدمت سيكويل سيرفر ٠٠١5‏ الأنواع القصوى الجديدة 
varchar)max>), nvarchar(max), varbinary(max)‏ وهي مخصصة 
للتعامل مع الكائنات الثنائية الضخمة «Binary Large Objects (BLOBs)‏ 
فهي تستطيع استقبال بيانات يصل حجمها إلى حوالي ۲ جيجا بايت» كما يمكنها 
التعامل مع البيانات الثنائية والحروف بطريقة تتابعية «Sequential‏ أي أنك 
تستطيع الكتابة فيها في أي موضعء أو القراءة منها من أي موضع.. 
لهذا إذا كنت تنوي التعامل مع بيانات ضخمة 4810138 فالأفضل أن تستخدم: 
- النوع (كعتهدم)تقطءج7 بدلا من النوع ٣×٤‏ . 
- والنوع (عتهده)تقطءععهتام بدلا من النوع زع01. 
- والنوع (×4)راه "1ط بدلا من النوع مع 2دم1. 
وللكتابة التتابعية في هذه الأنواع الجديدة» قدمت ,1-5001 الصيغة الجديدة التالية 
لأمر التحديث: 
اسم_الجدول UPDATE‏ 
.WRITE (@Value, @Offset, @Length (‏ اسم_العمود SET‏ 
شرط Where‏ 
فالدالة الداخلية 1776 تكتب البيانات المرسلة إلى المعامل عمںاه ۷© في الخانة 
المحددة في العمود» بدءا من الموضع «@Offset‏ وبحيث يكون طول البيانات 
المكتوبة طاعرم1@.. لاحظ ما يلي: 
- هذه الصيغة ستسبب خطأ إذا حاولت التعامل مع أي نوع بيانات غير 
الأنواع القصوى التي تنتهي ب .(MAK)‏ 
- هذه الصيغة ستسبب خطأ إذا حاولت إضافة بيانات فى خانة قيمتها 71111.. 
لهذا أمامك حلان: ١‏ 
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-١‏ فإما أن تضيف الجزء الأول من البيانات باستخدام الصيغة العادية 
للأمر ع09م11» ثم تضيف باقي أجزاء البيانات باس تخدام 
الصيغة Update .Write‏ . 
- وإما أن تمنع استخدام القيمة 7111 في خانات العمودء وفي هذه الحالة 
عليك استخدام قيمة افتراضية لوضعها في الخانات الفارغة؛ وذلك 
بوضع القيمة صفر في الخاصية Default Value Or Binding‏ في 
خصائص العمود.. ولكي لا تؤثر هذه القيمة الافتراضية على القيمة 
التي ستضعها في خانات العمودء يجب أن تكون للمعامل 011566 ©) 
القيمة صفر عند كتابة أول جزء من البيانات» لتوضع في بداية الخانة 
بدلا من أية بيانات موجودة. 
- إذا أرسلت إلى المعامل 5716© القيمة 71011 فسيتم تجاهل المعامل 
«@Length‏ وسيتم حذف القيمة الموجودة في الخانة في الموضع المحدد 
في المعامل 0۴5e‏ @. 
- إذا أرسلت إلى المعامل ء0۴6 القيمة 1١ء‏ فسيتم تجاهل المعامل 
engthا@»‏ وستضاف قيمة المعامل عں اه۷ @ إلى نهاية البيانات 
الموجودة حاليا ف الخانة 
- إذا أرسلت إلى المعامل 011566 @ قيمة أكبر من طول البيانات الموجودة 
في الخانة» فسيحدث خطأ.. ولكي تكتب بعد نهاية البيانات الموجودة» يجب 
أن ترسل إلى المعامل 011561 @ قيمة تساوي طول البيانات الموجودة في 
الخانة» أو ترسل إليه القيمة 7111 كما أوضحنا في الملحوظة السابقة. 
2 اا أرسلت إلى المعامل @Length‏ القيمة Null‏ فسيتم حذف جميع 
البيانات التالية للموضع المحدد في المعامل ع0۴ ©). 
وستجد مثالا لاستخدام هذه الصيغة لكتابة بيانات صورة أول ناشر في العمود 
2 في الجدول 206115615 بطريقة تتابعية» وذلك في الزر 
Update . Write‏ في المشروع 71711612156102362: وفيه نستخدم الاستعلام: 
UPDATE Publishers‏ 
SET Logo2 .WRITE (@Logo, @Offset , (@Length)‏ 
WHERE ID =1‏ 
لاحظ أن العمود02عم] من النوع cvarbinary(MAX)‏ وأن قيمته الافتراضية 
هي ..٠‏ ولكتابة بيانات الصورة في الخانة الأولى من هذا العمود تتابعياء سنرسل 
أول ٠‏ وحدة ثنائية م)ر8 لحفظها في الخانة بدءا من الموضع رقم صفرء ثم 
نرسل ٠‏ وحدة تالية لحفظها في الخانة بدءا من الموضع رقم ٠‏ ونستمر في 
فعل هذا إلى أن ننتهي من كتابة بيانات الصورة.. هذا معناه أننا سنستخدم الاستعلام 
Update . Write‏ عدة مرات (وذلك من خلال حلقة تكرار م1.00)» لکن مع تغيير 
المعاملات المرسلة إلى الدالة الداخلية .Writ‏ في كل مرة.. طبعا إرسال ٠٠١‏ 


وحدة ثنائية فى كل مرة» أفضل بكثير من إرسال ٠١‏ ميجا أو أكثر دفعة واحدة.. 
لكن هذا قد يصير عبئا خطيرا على البرنامج إذا كانت الصورة ضخمة جداء بسبب 
زيادة عدد مرات إرسال البيانات من العميل إلى الخادم.. لهذا عليك اختيار حجم 
مناسب لأجزاء البيانات التي ترسلهاء بحيث لا يكون كبيرا جدا فيدمر الذاكرة 
ويبطئ عملية الإرسال» ولا يكون صغيرا جدا فيؤدي إلى إضاعة وقت كبير من 
الخادم بسبب كثرة عدد الأوامر المرسلة إليه من عميل واحد.. ربما يكون الأنسب 
مثلا أن تستخدم ٠١75‏ وحدة ثنائية ١(‏ كيلو بايت) لكل جزء.. لكن هذا سيجعلك 
ترسل الصورة التي حجمها ١‏ ميجا فقط على حوالي ٠٠٠١‏ مرة.. ما زال هذا يبدو 
كثيرا.. أليس كذلك؟.. لو شئت رأيي» فإن إرسال ٠٠١‏ كيلو في كل مرة سيكون 
مناسباء فهذا سيرسل الصورة التي حجمها ١‏ ميجا باستخدام ٠١‏ أوامر فقط وهذا 
ليس كثيراء كما أن ٠٠١‏ كيلو ليس بالحجم المقلق الذي يستغرق وقتا ملموسا عند 
إرساله إلى الخادم.. لكن عليك في هذه الحالة أن تجعل للخاصية 111060116 
الخاصة بالاتصال الذي تستخدمه قيمة أكبر قليلاء ولتكن ٠٠١‏ ثانية على سبيل 
الاحتياط.. وسنعرف كيف نفعل هذا لاحقا عند دراسة كائن الاتصال وكائن الأمر. 
ملحوظة: 

الإصدارات القديمة من ,1-5001» كانت تستخدم الأوامر 11210817111131 و 
READTEXT‏ و :7111171121 للتعامل مع البيانات الضخمة الموجودة 
في الأعمدة من النوع عع1032 أو ×ع† أو ×ه)م.. لكن لا ينصح باستخدام هذه 
الأوامر الآن لأنها ستزال من لغة الاستعلام» وبدلا من هذا عليك استخدام 
الأنواع القصوىء والصيغة .Update . Write‏ 








اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 
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لغة تعريف البيانات :Data Definition Language (DDL)‏ 
تختص أوامر هذه اللغة بإنشاء أو حذف كائنات قاعدة البيانات» مثل الجداول وما 
تحتويه من أعمدة وفهارسء ومثل العلاقات 613605 والقيود ومتهناومه©. 
ولن نتوسع في شرح هذه الأوامر في هذا الكتاب» وسنتركها إلى الكتاب الذي نشرح 
فيه 7-901 بإذن الله» ويمكنك أن تبحث في ملفات استعلام اللغة عن كيفيّة 
استخدام الأوامر التالية» وهي تستخدم لإنشاء عناصر قاعدة البيانات: 
CREATE DATABASE‏ 
CREATE TABLE‏ 
CREATE PROCEDURE‏ 
CREATE FUNCTION‏ 
CREATE VIEW‏ 
CREATE INDEX‏ 
ولتعديل عناصر قاعدة البيانات» تستخدم الكلمة 4117111 بدلا من الكلمة 
..)R ۸1٤‏ ولحذف أحد العناصرء تستخدم الكلمة 5۸0۲ بدلا من الكلمة 
.CREATE‏ 
ويمكنك الاسترشاد بهذه الأمثلة (وهي خاصة بقواعد بيانات :(Access‏ 
الجملة التالية تنشئ جدولا للمؤلفين» به عمودان يستوعبان نصوصا لا يزيد طولها 
0 عن ٠٠١‏ حرفاء مع ملاحظة أن العمود الثاني مفهرس (بإنشاء فهرس اسمه ×) مع 
عدم السماح بتكرار القيم: 
Create Table Authors‏ 
([Author] Text (30), [City] Text (20) Constraint X‏ 
Unique)‏ 
أما الجدول التالي» فله عمود رقمي» والاخر ترقيم تلقائي: 
Create Table Numbers‏ 
([No|] Integer,[ID] Counter)‏ 
ولإنشاء فهرس اسمه × على العمود (11 في الجدول السابق: 
Create Unique Index X On Numbers (No)‏ 
ولإضافة عمود اسمه مآ للجدول السابق: 
ALTER TABLE Numbers‏ 
ADD COLUMN Y Long‏ 
ولحذفه مرّة أخرى: 
ALTER TABLE Numbers DROP COLUMN Y‏ 


:Stored Procedures الاجراءات المخزانة‎ 


YY 


الإجراءات المخزّنة هي برامج قصيرة مكتوبة بلغة ,1-5001 محفوظة في قاعدة 
البيانات» ويتم تنفيذها على الخادم 7م:ع5» لأداء وظيفة معيّنة على قاعدة البيانات. 
ويمتاز الإجراء المخزن بالمميزات التالية: 
-١‏ يقوم S۷٥۲‏ ,501 بترجمة ج11مرمه00 الإجراءات المخزّنة مرّة واحدة 
عند إنشائهاء وبالتالي فهي تعمل أسرع من جمل ,501 العاديّة. 
”. اختضنار الكود» بسيب قدرتك على استدذعاء نفس الإجراء المكخزن: من 
برامج مختلفة أو من أكثر من موضع من نفس البرنامج. 
"- سهولة التعديل في الإجراء المخزن بدون تغيير أكواد البرامج التي 
تستخدمه» وذلك لأنه موجود فى قاعدة البيانات. 
4- الإجراءات المخزنة أكثر مناعة ضد دس الاستعلامات 0نjectہ1 SQL‏ 
كما سنرى فيما بعد. 
وتسمّى اللغة التي تكتب بها الإجراءات المخزّنة ,7-501 اختصارا ل 
(1532531-5001)» وهي نسخة مطورة من ,5001 خاصة بسيكيول سيرفر كما 
ذكرنا سابقا. 
ويبدأ الإجراء المخزن بجملة التعريف التالية: 
CREATE PROCEDURE dbo.SP1‏ 
حيث إن 981 هو اسم الإجراءء ويمكنك تغييره إلى أي اسم يناسبك. 
لاحظ أن الجملة CREATE PROCEDURE‏ تستخدم عند إنشاء الإجراء 
المخزن للمرة الأولى» لكن بمجرد حفظه تتحول إلى AL1٤۸‏ 
15 م66 لأنك ستعدل فيه بعد ذلك ولن تعيد إنشاءه من جديد.. ولو 
حاولت استخدام CREATE PROCEDURE‏ مع نفس اسم الإجراء المخزن 
مرة أخرى فستحصل على خطأ يخبرك أن هذا الإجراء موجود من قبلء لهذا لو 
كنت تقصد إعادة حفظ نفس الإجراء بعد التعديل» فتأكد من أنه يبدأ بالفقرة 
„ALTER PROCEDURE‏ 
بعد هذا يأتي تعريف معاملات الإجراء.. وتبدأ المتغيّرات في لغة ,7-501 بالرمز 
@.. والجملة التالية تعرّف معاملا نصيا طوله ثلاثة أحرف: 
(@Str1 nvarchar(3)‏ 
كما ترى: تكتب اسم المعمل» يليه نوعه. 
وعند وجود أكثر من معامل» توضع العلامة "," للفصل بينها. 
ويمكن أن تضع للمعامل قيمة افتراضيّة» بحيث لو لم يُرسل هذا المعامل» يقوم 
الإجراء باستخدام هذه القيمة: 
'افتراضي' = (2521181:)7 @Str2‏ 
وتوضع معاملات الإجراء بين قوسين ()» ولا يشترط أن تكتب في سطر واحد. 
ويبدأ الإجراء المخزّن بالكلمة ۸68 وينتهي بالكلمة R۸‏ ۲0 ۸» وبينهما الكود: 
AS‏ 
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RETURN 
:1219014[+17 ويمكنك أن تعرّف المتغيّرات داخل الإجراءء باستخدام الجملة‎ 
DECLARE @Str3 nvarchar(7) 
ويمكنك كتابة جمل الشرط كالتالي:‎ 
IF @Str3 = " 
BEGIN 
SELECT @Str3 = 'ABC' 
END 
:END و‎ BEGIN وإذا كان مقطع الشرط جملة واحدة« فلسنا بحاجة إلى‎ 
IF @Str3 = "' 
SELECT @Str3 = 'ABC' 
لاحظ استخدامنا للتعبير 518158001 لتغيير قيمة المتغيّر 53 @.. يمكنك كذلك‎ 
:S ٤٤٣1 استخدام التعبير '51:1 لتغيير قيمة المتغيّرء وهو ليس مربكا مثل‎ 
SET @Str3 = 'ABC' 
طبعا إذا كانت تعيد قيمة‎ - S81٤٥ 1 ويمكن أن تضع في المتغيّر ناتج جملة‎ 
أو يكون‎ Aggregate 11011005 واحدة» كأن تكون بها دالة من دوال التجميع‎ 
الجدول الناتج عبارة عن خانة واحدة  كالتالي:‎ 
SET @Str3 = (SELECT Book FROM Books WHERE ID = 3) 
والآن» ما رأيك أن نكتب إجراء مخزنا نرسل إليه اسم المؤلف» فيعيد إلينا الكتب‎ 
التي ألفها؟‎ 
في متصقح خوادم الإنترنت 1ع:10م12 ١م۷إمS» أسدل العناصر التي تنتمي‎ 
لاتصال قاعدة البيانات 800125.52014 التي أنشأناها ب ه567 ,501.. من هذه‎ 
51060 العناصر اضغط بزل الفأرة الأيمن على "الإجراءات المخزّنة"‎ 
New Stored ومن القائمة الموضعيّة اضغط الأمر‎ »: 5 
1ع . ستظهر لك نافذة تحرير الإجراء المخزّن.. اكتب بها هذا الإجراء:‎ 


٤ 


CREATE PROCEDURE dbo.GetAuthor Books 


لدينا معامل واحد فقط نستقبل فيه اسم المؤلف*/ 
/* وقد جعلناه ٠١‏ حرفا ليتلاءم مع طول حقل المؤلفين 


@Author char(0) 

) 
AS‏ 
/*تأگد أن اسم المؤلف غير فارغ */ ">< IF @Author‏ 
BEGIN‏ 

/*هذه جملة استعلام عاديّة تماما*/ 

SELECT Book 

FROM Books, Authors 

WHERE Author = @Author 

AND AuthorID = Authors.ID 

END 


/*وجود هذه الكلمة في أي موضع يؤذي إلى إنهاء الإجراء*/ RETURN‏ 
أعتقد أن الأمر فى غاية البساطة. 
ولا حاجة بي لألفت نظرك إلى أن التعليق في لغة ,7-501 يوضع بين العلامات 
/* */.. هذه الرموز تتيح لك كتابة التعليق على أكثر من سطر.. فإذا أردت أن 
تكتب سطرا واحدا كتعليق» فيمكنك أن تضع في بدايته العلامتين --.. مثال: 
هذا تعليق */ 
/*على سطرين 
بينما هذا تعليق في سطر واحد-- 
ولا بد أنك لاحظت ظهور الجملة S٤٤٣1‏ في نافذة الإجراء السابق في 
مستطيل.. اضغط بزل الفأرة الأيمن داخل هذا المستطيل» ومن القائمة الموضعيّة 
اختر الأمر "تصميم مقطع الاستعلام" 81016 .501 1(68180.. ستظهر لك نافذة 
باني الاستعلام 1811110 yاعQu»‏ حيث يمكنك استغلاله لتطوير الجملة 
واختبارها. 
كما يمكنك استخدام باني الاستعلام لتصميم جملة 501 مباشرةٌ منذ البداية.. اضغط 
بزر د الفأرة الأيمن في الموضع الذي تريد كتابة الجملة فيه في الإجراء المخلتد 
ومن القائمة الموضعيّة اضغط الأمر .Insert SQL‏ . ستظهر لك نافذة باني 
الاستعلام. . صمّم جملة 8Q1‏ التي تريد» وقم بحفظ العمل. . الآن لو عدت إلى نافذة 
الإجراء المخزّن» فستجد أن جملة 8Q1‏ قد أضيفت للموضع الذي ضغطت فيه 
الفارة. 


نريد الآن اختبار الإجراء الذي كتبناه.. اضغط بزر الفأرة الأيمن في أي موضع من 
نافذة الإجراءء ومن القائمة الموضسعيّة اضغط الأمر 
..R un Stored Procedure‏ ستظهر لك نافذة تسألك عن قيمة معامل الإجراء.. 
اكتب اسم (توفيق الحكيم) واضغط >01.. سيتمٌ تنفيذ الإجراء» حيث ستظهر أسماء 
كتب (توفيق الحكيم) في نافذة المخرجات .Output Window‏ 


اعد بيانات ووع4©©6: 


على عكس ما يظنه الكثيرون» يمكن استخدام الإجراءات المخزنة مع قواعد بيانات 
آكسيس.. لكن المشكلة أنك لن تجد طريقة لإنشائها في آكسيس نفسه»ء كما أنك لا 
تستطيع إنشائها في متصفح الخوادم 1201011 5611 في دوت نت» رغم أنك 
ستجد عنصرا اسمه 2706011165 0م5101 ضمن عناصر قاعدة بيانات الكتب 
Books.mdb‏ ! 
فما هو حل هذا اللغز العجيب يا ترى؟ 
الحل هو تنفيذ الجملة التي تنشئ الإجراء المخزن من خلال كود فيجيوال بيزيك في 
أحد برامجك لمرة واأحدة وبهذا يتم إنشاء الإجراء المخزن في قاعدة بيانات 
اک ويظهر في e‏ الخوادم تحت ا ..Stored Procedures‏ طبعا 
بعض الاختلافات الجوهرية بين الإجراء المخزن الخاص باكسيس والإجراء 
المخزن الخاص بسيكويل سيرفر 
-١‏ يستخدم أكسيس التعبير CREATE PROC‏ بدلا من التعبير CREATE‏ 
.PROCEDURE‏ 
-١‏ الإجراء المخزن في آكسيس يتكون من جملة ,501 واحدة فقط لأن 
آكسيس لا يقبل تنفيذ أكثر من جملة مفصولة بالعلامة : 
7 ديم و تعرييده OEE‏ ا مزاع امقر فى لصم ون 
استخدام جمل الشرط.. السبب ببساطة أن آكسيس لا يتعامل مع 
.T-SQL‏ 
-٤‏ لا توضع العلامة @ قبل أسماء المعاملات الخاصة بالإجراء المخزن في 
آكسيس.. وطبعا أنواع هذه المعاملات هي الأنواع الخاصة بآكسيس. 
5- لا ينتهي الإجراء المخزن في أكسيس بالكلمة ٤10 R۸‏ ۸. 
باختصار: الإجراء المخزن في آكسيسء هو مجرد استعلام سيكويل مخزن! 
هكذا مثلا سيكون الإجراء المخزن الذي يحذف من جدول المؤلفين» المؤلف الذي 
ترسل اسمه إليه: 
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CREATE PROC DeleteAuthor( 
AuthorName VARCHAR{@20) ) 
AS 
DELETE FROM Authors 
WHERE (Authors.Author = AuthorName); 
ولك اق ها الإجسراء إلى قاع اعات الكتسيه تع المشروع‎ 
ورغ البرنامج» واضغط الزر‎ »AccessStored Procedure 
كما يمكنك إنشاء إجراء مخزن للحصول على كتب أحد‎ .."Delete Author" 
."GetAuhorBooks" المؤلفين» بضغط الزر‎ 
..©:١ لاحظ أن هذا البرنامج يفترض وجود الملف 80015.52 على المسار‎ 
وسنفهم الكود الذي يستخدمه هذا البرنامج بالتفصيل لاحقا.‎ 
بعد أن تنفذ هذا البرنامج» أضف اتصالا بقاعدة بيانات الكتب الموجودة على المسار‎ 
في متصفح الخوادم» وأسدل عناصرها.. ستجد أن الإجراءين‎ °: 
قد ظهرا تحت العنصر‎ GetAuhorBooks و‎ Delete Author 
لكن للأسف» لا يمنحك متصفح الخوادم أية طريقة‎ ..5016 Procedures 
لعرض كود هذين الإجراءين أو تعديلهما أو تشغيلهما.‎ 
ويريك الزر "الكتب١" في المشروع وع73010116 كيف يمكن استدعاء الإجراء‎ 
]ع من برنامجك› وسنفهم كيف يفعل هذا لاحقا.‎ 0135 


:User Defined SOL Functions دوال 50011 الت فها المستخدم‎ 





کک و دل خاصةء تستخدمها داخل استعلامات ,501: بنفس الطريقة التي 
استخدمنا بها الدالة ۸16[81.. هذه الدوال تحفظ في قاعدة البيانات تماما 
كالإجراءات المخزنة» وتظهر في متصفح الخوادم تحت العنصر 1"1011005. 
ويمكنك إنشاء دالة جديدة بإسدال عناصر قاعدة البيانات وضغط العنصر 
Functions‏ بزر الفأرة الأيمن» وضغط القائمة الفرعية سعN»›‏ حيث ستظهر لك 
ثلاثة أنواع من الدوال التي تستطيع إنشاءها.. لكن نظرا لأن هذا الموضوع يحتاج 
إلى تفاصيل أعمق في 1-901 فستنوجله إلى الوقت المناسيب بإذن الله. 
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أنواع الجداول التي يعرفها المستخدم :User-Defined Table Types‏ 
قدم سكيويل سيرفر ۲۰۰۸ نوعا جديدا من المعاملات» قادرا على استقبال جدول 
كامل يحتوي على مجموعة صفوف» بدلا من المعاملات العادية التي تستقبل قيمة 
خانة منفردة في أحد الصفوف.. هذا يغنيك عن استخدام عدد كبير من المعاملات 
عند تعريف الإجراء المخزن» كما يغنيك عن استدعاء نفس الإجراء المخزن أكثر 
من مرة. . فمثلا: لو أردت كتابة إجراء مخزن يقوم بتحديث قيم > صفوف بها 
عشرة أعمدة في أحد الجداول» فإن استخدام المعاملات التقليدية سيجبرك على 
تعريف ٠١‏ معاملات للإجراء المخزن (واحد لكل عمود)؛ واستخدام واستدعاء 
الإجراء المخزن 5 مرات لإرسال القيم إلى هذه الصفوف.. بينما إذا استخدمت 
معاملا جدوليا Parameter‏ 11601ج/1316-17؛ فستعرف معاملا واحدا فقط 
لخر له السخن قو مد ةه هر واه ققد خت الصنفوقه» الحممنة 
يبدو هذا مريحا للغاية» حيث سيوفر عليك كتابة الكثير من الكود في الإجراء 
المخزن وفي برنامجك أيضاء وسيجعل نقل كميات كبيرة من البيانات أمرا في غاية 
23 د 
ولاستخدام هذا النوع من المعاملات» يجب أن تقوم بتعريفه أولا في قاعدة 
البيانات.. ويشيه'تضدميم النوع تيم الجدول؛ لكن للأسف» الآ توجد طريقة مرائية 
لمحتن التواع :: لهذا عليك اة كود ]1-50 فل ها رومن اة د 
الاستعلامات في مدير سيكويل.. ويستخدم الأمر ۲۷۴٤‏ 011811 لإنشاء نوع 
جديد في ,1-5001» وذلك على الصيغة: 
AS TABLE‏ اسم_النوع CREATE TYPE‏ 
(تعريف_الأعمدة) 
دعنا ننشئ نوعا اسمه عمل آ٣٥طاں۸‏ نستطيع من خلاله تحدیث صفوف جدول 
المؤلفين.. لفعل هذا في مدير سیکویل» اضغط اسم قاعدة البيانات Books. df‏ 
بزر الفأرة الايمن» ومن القائمة الموضعية اضغط الأمر ›New Query‏ وفي نافذة 
الاستعلام اكتب الكود التالي: 
CREATE TYPE AuthorType AS TABLE‏ 
(ID int,‏ 
Author nvarchar(50),‏ 
CountryID smallint,‏ 
Phone varchar{20),‏ 
About nvarchar(MAX) )‏ 
من القائمة الموضعية اضغط عاںcع×E..‏ الآن سيظهر النوع 4110115706 تحت 
العنصر Programmabıility\Types\User defined Table Types‏ في 
متصفح الكائنات في مدير سيكويل سيرفرء حيث يمكنك تغيير اسمه لو أردت» كما 
يمكنك حذفه في أي وقت. 
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الآن يمكنك تعريف إجراء مخزن جديد يستخدم معاملا من هذا النوع.. لاحظ أنك لا 
تستطيع استخدام هذا المعامل للإخراج» كما أنك مجبر على تعريفه للقراءة فقط 
باستخدام الكلمة /آ118181(01771[1 كالتالي: 

CREATE PROCEDURE UpdateAuthors 

(@Rows AuthorType READONLY) 

لكن كيف نتعامل مع المعامل وس0 ۸@ في كود الإجراء المخزن؟ 
الأمر بسيط للغاية» فهذا المعامل هو جدول» ويمكنك التعامل معه في جمل .501 
كأي جدول عادي.. مثلا: يمكننا تحديث الجدول 114015 من الجدول 120175 @ 
باستخدام الأمر 0۲0۸1۴ والربط الداخلي 10171 NNER‏ كالتالي: 


CREATE PROCEDURE UpdateAuthors 
(@Rows AuthorType READONLY) 
AS 
UPDATE Authors 
SET Authors.Author = R.Author, 
Authors.CountryID = R.CountryID, 
Authors.Phone = R.Phone, 
Authors.About = R.About 
FROM Authors INNER JOIN @Rows AS R 
ON Authors.ID = R.ID; 
RETURN 


لاحظ ضرورة تعريف اسم مستعار للجدول sسR0@‏ في المقطع FROM‏ 
لتسهيل كتابة الاستعلام.. لقد منحناه هنا الاسم المستعار ۸. 

بهذا يمكنك استخدام هذا الإجراء المخزن لتحديث قيم سجلات مؤلفين موجودين 
بالفعل في قاعدة البيانات» بناء على تماثل الرقم 17 في السجل المرسل والسجل 
الأصلي. 

كما يمكنك تعريف إجراء لإدراج سجلات الدول المرسل كمعامل» في جدول 
المؤلفين» وذلك باستخدام الأمر ٣‏ ٤S؟N]..‏ هذا هو: 
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CREATE PROCEDURE InsertAuthors 
(@Rows AuthorType READONLY) 
AS 
INSERT INTO Authors 
(Author, CountryID, Phone, About) 
SELECT R.Author, R.CountryID, R.Phone, R.About 
FROM @Rows AS R 
RETURN 
لاحظ أنك لا تستطيع اختصار جملة الإداراج السابقة كالتالي:‎ 
INSERT INTO Authors 
SELECT R.* 
FROM @Rows AS R 
السبب في هذا هو أنك لا تستطيع نسخ قيمة الحقل 1 من سجلات المعامل إلى‎ 
سجلات الجدول الأصليء لأن الحقل (81101.11/ حقل يولد تلقائياء بينما نحن لم‎ 
نعرف الحقل (6.11م/4110115, على أنه یولد تلقائيا.‎ 
لاحظ أن تعريف المعامل الجدول بالكلمة 126300117 يمنعك عن إجراء أية‎ 
تعديلات على قيم سجلاته» كما يمنعك من حذف أي من هذه السجلات أو الإضافة‎ 
إليها.. لهذا إذا كنت مضطرا إلى فعل هذاء فعليك أن تعرف متغيرا من نفس نوع‎ 
مثال:‎ ..1NS8٤ R1 الجدول» وتدرج فيه سجلات المعامل باستخدام الأمر‎ 
DECLARE @TEMP AuthorType; 
INSERT INTO @TEMP 
SELECT R.* 
FROM @Rows AS R; 
لاحظ أننا استخدمنا صيغة الإدراج المختصرة (لم نكتب أسماء الأعمدة) لأن الحقل‎ 
لا يولد تلقائيا هنا.‎ 5 
بعد هذا يمكنك أن تضيف إلى الجدول 117117 @ سجلات جديدة أو تعدل قيم‎ 
السجلات الموجودة» ومن ثم تستخدمه في الكود كما تريد.‎ 
يريك كيف تستخدم كائن الأمر‎ "able Valued Para 1061615 والمشروع‎ 
والمعاملات لتنفيذ هذا الإجراء المخزن لإدراج عدد من المؤلفين في جدول‎ 
المؤلفين.. وسنتعرف على كائن الأمر 001112120) ومعاملاته في فصل لاحق.‎ 
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AD0O.N É1 تقنية‎ 


الخادم Server‏ وا :Client‏ 
الخادم Server‏ شيو حاسوب توجد عليه قاعدة البيانات» ويعمل عليه 
«SQL Server‏ لهذا فهو يقوم بقراءة البيانات المطلوبة وإرسالها إلى المستخدم أو 

استقبال البيانات الواردة من المستخدم وحفظها في قاعدة البيانات. 

بينما العميل +011 هو أي جهاز حاسوب آخر يوجد عليه برنامج قواعد البيانات 
الذي كتبته أنت» ويقوم بالاتصال بخادم سيكيول لطلب البيانات أو حفظها عليه. 
ويمكن أن يكون هناك آلاف العملاء 011645» كل منهم يحاول الاتصال بقاعدة 
البيانات على الخادم في نفس الوقت» وطلب البيانات منها لمعالجتها على أجهزتهم» 
ثم إرسال أيّ تعديلات تمّ إجراؤها عليها إلى الخادم مرّة أخرىء ليتمّ حفظها في 
قاعدة البيانات. 

ويقدم لنا نموذج الخادم والعميل الميزات التالية: 


وجود قاعدة البيانات على الخادم يوفر لمستخدميها مساحة التخزين 
(بدلا من وضعها على أجهزة كل المستخدمين)» خاصة حينما تكون قاعدة 
البيانات عملاقة. 

وجود قاعدة البيانات على الخادم يترك للجهة المسئولة عنها مهمّة تحديثها 
باستمرار» وهو أفضل من اضطرار كل مستخدم إلى شراء نسخة حديثة 
من قاعدة البيانات كل فترة. 

وجود قاعدة البيانات على الخادم يضمن مشاركتها بين مئات المستخدمين» 
مما يضمن مساهمتهم في إضافة البيانات وقدرة كل منهم على رؤية 
التعديلات التى أجراها الآخرء بينما لو كانت قاعدة البيانات على جهاز كل 
منهم بمفرده» فلن يمكنهم العمل الجماعي عليهاء وهذا لا يناسب نشاط 
الشركات التجارية والمؤسسات المالية. 

إجراء العمليّات على البيانات على جهاز العميل بعد الحصول عليها من 
الخادم» يكون أسرع بكثير من تنفيذ البرنامج على الخادم ثمّ إرسال الناتج 
إلى العميل» وذلك لأن هناك عددا ضخما من المستخدمين الذين يجرون 
آلاف العمليّات في نفس اللحظة. 
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وينظم خادم سيكويل عمليات الاتصال مع العملاءء حيث يخصص لكل اتصال 
عملية فرعية 1116230 للقراءة أو الكتابة في قاعدة البيانات.. ويتوقف عدد 
الاتصالات المتاحة في نفس اللحظة على حجم الذاكرة المؤقتة )1041 الموجودة 
على الجهاز الخادم وقوة المشغل الدقيق الخاص به.. وفي حالة ازدياد الضغط على 
الخادم يقوم بتأجيل الاستجابة لبعض العملاء إلى حين الانتهاء من خدمة العملاء 
السابقين» مما قد يؤدي إلى بطء برنامجك وتضايق مستخدميه بسبب تعطله عن 
الاستجابة لفترات طويلة.. لهذا تقع على برنامجك مسئوليّة ضمان كفاءة عمليات 
الاتصال بقاعدة البيانات» بمراعاة ما يلى: 
- ألا يطلب برنامجك بيانات لا ضرورة لها.. فإن كنت تحتاج مثلا إلى حقل 
أو حقلين من الجدولء فما الداعى لأن تقرأ كل الحقول؟ 
- التأكد من كتابة أقصر وأكفأ استعلامات ,501 ليكون تنفيذها أسرع فلا 
ترهق الخادم. 
- الاحتفاظ ببعض البيانات المجهزة 025160 على جهاز العميل بدلا من 
إعادة طلبها أكثر من مرة فى فترات زمنية صغيرة» وذلك إذا كنت تضمن 
عدم تغير هذه البيانات بسرعة كبيرة.. وإذا كانت هذه البيانات ستظل ثابتة 
لجميع العملاء لفترة طويلة» فيمكن تجهيزها على الخادم وإرسالها إليهم 
مباشرة كلما طلبوها بدون إعادة تنفيذ الاستعلام» ولا يتم تحديث البيانات 
المجهزة إلا إذا حدث تغيير فيها في قاعدة البيانات. 
مثل هذا التنظيم يضمن تخفيف عبء هائل من على خادم سيكويل وتقليل جمل 
1 التي ينفذهاء وبالتالي يوفر قدرة المشغل الدقيق :رمووععمء7 والذاكرة 
4 الخاصة بالحاسوب الذي يعمل عليه خادم سيكويل» ليستطيع تنفيذ عمليات 
أخرى. 
كما أن هناك بعض التحذيات التي تواجه المبرمج وهو يكتب برنامجا يتعامل مع 
الخادم» مثل التعارض الذي يمكن أن ينتج عندما يحذف أحد المستخدمين بعض 
السجلات» بينما مستخدم آخر يحدّث قيمها!.. أو عندما يحاول أكثر من مستخدم 
تحديث نفس السجلات بطرق مختلفة في نفس الوقت.. وسنرى كيف نواجه مثل هذا 
الأمر لاحقا. 


۲ 


تقنية :ADO0.NET‏ 
لكر :6ه مني اخ ال اتان ات ان 
Data Object‏ ×tiveءA»‏ وهي تقنية برمجية ظهرت في فيجيوال ستديو ٠٦‏ تقدم 
جميع الفنات 0138565 اللازمة للاتصال بقاعدة البيانات وطلب البيانات منها 
وحفظها فيها.. وتفترض هذه التقنية أن العميل سيظل على اتصال بقاعدة البيانات 
طوال مذة تعامله معها عبر الشبكة» حيث يحصل على البيانات من أيّ جدول يريده 

ويحدثها عبر نفس الاتصال. 





لكن هذه الطريقة كانت عقيماء ففتح الاتصال طوال الوقت مع قاعدة البيانات عبر 
الشبكة غير عملي لأنه يعطل مستخدمين آخرين عن الاتصال بقاعدة البيانات عند 
تجاوز عدد المتصلين في نفس اللحظة الحد المسوح به؛ كما أنّ إجراء العمليّات 
عبر الشبكة أبطأ من إجرائها على جهاز المستخدم.. كل هذا جعل المبرمجين 
يستخدمون تقنية ۸50 بطريقة غريبة» فقد كانوا يتصلون بقاعدة البيانات 
وينسخون البيانات المطلوبة إلى أجهزتهم» ثم يغلقون الاتصال ويجرون العمليّات 
المطلوبة على البيانات على أجهزتهم.. وإذا كانت هناك تغييرات يجب حفظها في 
قاعدة البيانات» يتصلون بقاعدة البيانات مرّة أخرى ويحفظون البيانات ثمّ يغلقون 
الاتصال. 


وقد أخذت ميكروسوفت هذا الأمر بعين الاعتبار» وطورت تقنية ۸0 مع ظهور 
فيجيوال سنديو دوت نت ”.60”.وصارت التقنية الجديدة تحمل الاسم 
0.۴1( فصار بالإمكان التعامل مع البيانات بعد إغلاق الاتصال فيما عرف 
باسم "التعامل المنفصل" 21006 101500116160» حيث يتصل المستخدم بقاعدة 
البيانات ويقوم بتحميل البيانات منها إلى الذاكرة ويغلق الاتصالء ليتعامل مع هذه 
البيانات على جهازه» وعندما يريد حفظ التغييرات» يفتح الاتصال مرّة أخرى لنقل 
البيانات إلى قاعدة البيانات. 


وفيما يلي تلخيص للخطوات التي تقوم بها عبر تقنية '41(0.71111/ للحصول على 
البيانات وتحدينها: 
- في البداية عليك أن تقوم بالاتصال بقاعدة البيانات بواسطة كائن الاتصال 
..0nnection object‏ هذا الكائن يتيح لك توضيح اسم قاعدة البيانات 
وكيفية الاتصال بها. 
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- بعد هذا عليك استخدام كائن الأمر ]نوءز0 7320تدطه©» الذي يتولى 
تنفيذ جملة الاستعلام 0106157 SQ‏ عبر الاتصال المفتوح. 


- بعد هذا يكون أمامك أحد اختيارين: 


.١‏ فإما أن تستخدم قارئ البيانات 162061 وه( لقراءة نتائج الاستعلام 
مباشرة دون حفظها على جهاز العميل. 


۲. وإما أن تستخدم "موصل البيانات" 1461م4013 1238 لحفظ نتائج 
الاستعلام على جهاز العميل في مجموعة البيانات ]ع5 وه( التي 
يمكن القول إئها صورة مصغرة من قاعدة البيانات» تحتوي على 
الجداول والعلاقات 136025ع12» والقيود 0002518115 المفروضة 
غ فكو الق وا فی ا تردن اه نسل الف عمقي 
Integrity‏ اReferentia‏ بين الجداول. 


- بعد هذا عليك إغلاق الاتصالء ومعالجة البيانات في برنامجك.. ويمكنك 
عرض البيانات للمستخدم لقراءتها أو تعديلها باستخدام أدوات ربط البيانات 
.Data Bound Controls‏ 
- وإذا كانت هناك أية تغييرات أجراها المستخدم على البيانات وتريد حفظها 
في قاعدة البيانات» فعليك استخدام كائن الاتصال مرة أخرى للاتصال بهاء 
واستخدام كائن الأمر أو موصل البيانات لتنفيذ استعلام التحديث. 
كماترى: يعتمد هذا التنظيم على تقسيم العمل إلى طبقات 5] مستقلة في 
وظيفتهاء وبهذا يسهل عليك التعديل في أي طبقة دون هدم الطبقات السابقة أو التالية 
لهاء مما يوفر الوقت والجهد. 


والشكل التالي يلخص هذه التقنية: 


١ 










قاعدة البيانات 


Database 
Server الخاداددم‎ 


العمطييل Client‏ 
كائن الاتصال 


Connection Object 


كائن الأمر 
Command Object‏ 










موصل البيانات 
Data Adapter‏ 










قارئ البيانات 
Data Reader‏ 






مجموعة البيانات 
Data Set‏ 







أدوات عرض البيانات 


Data-Bound Controls 


وتوجد فئات ۸00.N ٤۲‏ في نطاقات الأسماء وعع2م5و226ج]7 التالية: 
System.Data‏ - 
System. Transactions‏ - 
Microsoft.SqlServer.Server‏ - 


To 





الحروف ,7041 هي اختصار للتعبير "لغة التوصيف القابلة للتمديد" 
Markup Language‏ eاExtensib»‏ وهي طريقة لتمثيل أي بيانات لها تركيب 
منظم» وذلك بتحويلها إلى نص يعبّر عنها.. لهذا تصلح لغة ,5341 للتعبير عن أي 
نوع من أنواع البيانات» كالجداول والصور وغيرهما. 

ورغم أن الملقات النصّيّة أكبر حجما من الملقات الثنائيّة وع111 Bry‏ إلا إن 
مشاكل اختلاف طرق تمثيل البيانات الثنائية.. لهذا صارت لغة ,72341 في السنوات 
الأخيرة أنسب وسيلة لنقل البيانات عبر الإنترنت» لأنها تتجاوز مشاكل عدم التوافق 
بين التطبيقات وأنظمة التشغيل المختلفة.. ولهذا تستخدم تقنية ۸500.۴1 لغة 
51 في نقل البيانات بين الخادم والعميل. 

ورغم أن إطار العمل يقدم دعما كاملا للغة ۷1× ويتيح لك كتابتها وقراءتهاء إلا 
أنك لن تحتاج إلى هذا عند التعامل مع قواعد البيانات» لأنّ تقنية '1(0.711:1/ 
تستخدم لغة 1× كطبقة داخليّة» فهي تنتجها وتقرأ البيانات منها بطريقة آليّة. 
ومن الإمكانيّات التي تتيحها لك لغة ›×M1‏ قدرتك على استخدامها لإنشاء 
مجموعة بيانات ٥5و52‏ بدون الاعتماد على أي قاعدة بيانات. . في هذه الحالة 
ستوضع البيانات في الذاكرة» ولو شئت الاحتفاظ بهاء فيمكنك حفظها في ملفء ثم 
إعادة تحميلها مرة أخرى حينما تريد. . وسنتعرف على هذا بتفصيل اكبر لاحقا. 


مزودات قواعد البيانات :Database Providers‏ 
توفر تقنية ۸50.۴1 عدة مزودات 20110615 للتعامل مع أنواع مختلفة من 
قواعد البيانات.. وهذه المزودات هي: 


:ODBC -١ 
اسم هذا المزود هو اختصار للمصطلح "التواصل المفتوح مع قواعد‎ 
البيانات":‎ 
Open Database Connectivity 
۹۲ وقد طورت ميكروسوفت هذه التقنية  بالتعاون مع اخرين» عام‎ 
لتوفر طريقة عامة للتعامل مع قواعد البيانات بغض النظر عن لغة‎ 
البرمجة المستخدمة ونظام التشغيل الذي تعمل عليه؛ وتطبيق قواعد‎ 
البيانات المستخدم.‎ 
وتوجد فئات هذا المزود في النطاق:‎ 
System. Data.ODBC 
:OLE DB -" 


۳١ 


-۳ 





اسم هذا المزود هو اختصار للمصطلح "قاعدة بيانات ربط وتضمين 
الكائنات": 

Object Linking and Embedding Database 
كتطوير‎ C0 وهو مزود 8071061 بنته ميكروسوفت باستخدام تقنية‎ 
وتحسين لتقنية :01(8©0)» للتعامل بطريقة عامة مع أي نوع من أنواع‎ 
قواعد البيانات» لهذا تستطيع استخدامه للتعامل مع آكسيس (فليس لقواعد‎ 
بياناته مزود خاص بها)ء وكذلك مع قواعد ب بيانات سيكويل سيرفر‎ 
وأوراكل (رغم أن لكل منهما مزودا خاصا بهما)» ومع أي نوع آخر من‎ 
أنواع قواعد البيانات» حتى ولو لم تكن تدعم استخدام لغة ,5001 مثل‎ 
الجداول الشاملة 5]اعع[16305م5 الخاصة بتطبيق إكسيل 1ع120.‎ 
وتوجد فئات هذا المزود في النطاق:‎ 

System. Data.OleDb 


:SQL Server 
توفر دوت نت دعما خاصا لسيكويل سيرفر باعتباره أهم تطبيقات قواعد‎ 
البيانات التي أنتجتها ميكروسوفت بعد انتشار استخدام الشبكات والإنترنت‎ 

في عالم التجارة والأعمال. 
وتوجد فئات هذا المزود في النطاقات التالية: 


5010111 أفنتات مزود سيكويل سيرفر. 
System. Data.SQL‏ يقدم بعض الوظائف الخاصة 

بسيكويل سيرفر. 

59 ++ ايحتوي على فئات تمثل أنواع 

البيانات وعم1597 1238 الخاصة 

بسيكويل سيرفرء ليمكنك استخدامها 

بدلا من أنواع البيانات الموجودة في 

إطار العمل 

6171.511 7211005011.5015 | يحتوي على الفئات اللازمة لتشغيل 

سيكويل سيرفر في دوت نت. 
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:SQL Server Compact 3.5 =“‏ 
يتيح لك هذا المزود التعامل مع قواعد البيانات المنشأة بالنسخة الخفيفة من 
سكيويل سيرفر Server Compact Edition‏ /501: المخصصة 
لإنشاء قواعد بيانات للأجهزة الكفية المحمولة» التي تتعامل مع النسخة 
الخفيفة من الويندوز ٣٤‏ 71/120075 والنسخة الخفيفة من إطار العمل 

..NET Compact Framework 

وتوجد فئات هذا المزود في النطاق: 
System. Data.SqlServerCe‏ 
لكن استخدام هذا النطاق يتطلب منك أولا إضافة مرجع إليه في برنامجك» 

علما بأنه يوجد في الملف: 
system.data.sqlserverce.dll‏ 


:Oracle =°‏ 
قدمت ميكروسوفت منذ إصدار دوت نت 23٠٠7‏ دعما للتعامل مع قواعد 
بيانات أوراكل» فهي تمتاز بالقوة والشهرة والانتشار. 
وتوجد فئات هذا المزود في النطاق: System. Data.OracleClient‏ 
لكن استخدام هذا النطاق يتطلب منك أولا إضافة مرجع إليه في برنامجك» 
علما بأنه يوجد في الملف: 
System. Data.OracleClient.d11‏ 


وعليك أن تلاحظ أن جميع هذه المزودات توفر نفس أدوات الاتصال بقاعدة 
البيانات (كائن الاتصال 00161102©» كائن الأمر 3ه » موصل البيانات 
Data Adapter‏ مجموعة البيانات غع1(325: قارئ البيانات ...DataReader‏ 
إلخ)»؛ لكن كلا منها يبدأ باختصار يوضح نوع المزود» مثل: 


SqlCeConnection 
SqlConnection 
OdbcConnection كائنات الاتصال‎ 
OleDbConnection 
OracleConnection 
SqlCeCommand 
SqlCommand 
OdbcCommand كائنات الأمر‎ 
OleDbCommand 
OracleCommand 
SqlCeDataAdapter موصلات البيانات‎ 
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SqIDataAdapter 
OdbcDataAdapter 
OleDbDataAdapter 
OracleDataAdapter 
SqlDataSet 
OdbcDataSet 
OleDbDataSet 
OracleDataSet 
SqlCeDataReader 
SqIDataReader 
OdbcDataReader قارئات البيانات‎ 
OleDbDataReader 
OracleDataReader 


ونظرا لأنه لا توجد فروق تذكر بين أنواع الكائنات الخاصة بأحد المزودات 
والكائنات الخاصة بنوع آخرء فسنقتصر في هذا الكتاب على شرح مزود سيكويل 

سيرفر» اي ارم اسك ا ا 
نطاق الاسم والبادئة التي د تسبق اسم كل كائن من كائنات التعامل مع قاعدة البيانات! 


مجموعات البيانات 








اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 
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ل" — 
كائن الاتصال 


Connection Object 


يتيح لك هذه الكائن الاتصال بقاعدة بيانات تعمل على الخادم.. وكما ذكرنا سابقاء 
سنركز هنا على دراسة الفئة «sqlConnection‏ لهذا لا تنس إضافة جملة 
التضمين التالية أعلى صفحة الكود: 

Imports System.Data.SqIClient 


نص الاتصال :Connection String‏ 
للاتصال بسيكويل سيرفرء يجب أن ترسل إليه نصا يحتوى على البيانات اللازمة؛ 
مثل اسم قاعدة البيانات» واسم المستخدم وكلمة السر.. ويتكون نص الاتصال من 
مجموعة من القيم» يفصل بين كل منها العلامة ; وذلك على الصيغة: 
Propertyl = Valuel; Property2 = Value2; ..............‏ 
PropertyN = ValueN‏ 
على سبيل المثال» النص التالي هو نص الاتصال بقاعدة بيانات الكتب على سيكويل 
سيرفر: 
Data Source = .\SQLEXPRESS;‏ 
AttachDbFilename = C:\Books.mdf;‏ 
Integrated Security = True;‏ 
Connect Timeout = 30;‏ 


ملحوظة: 

عند بناء نص الاتصال بمزود 01(8)00» عليك وضع القيم بين قوسين متعرجين 

إ )» على الصيغة: 

Property] = {Valuel}; Property2 = {Value2}; ....... 
PropertyN = {ValueN} 

بينما في باقي المزودات يمكنك استخدام علامات التنصيص بدلا من الأقواس 

المتعرجة. 





وتختلف بعض الخصائص المرسلة عبر نص الاتصال» تبعا لنوع مزود قاعدة 
البيانات المستخدم.. وقد كانت كتابة نص الاتصال تمثل مشكلة قبل ظهور الإصدار 
الثاني من إطار العمل مع دوت نت كت ا ايه حيث وفر إطار العمل فئة خاصة 
تسمى "باني نص الاتصال" 13111101ع 120002261005111 ومنها تم اشتقاق 
فئة لبناء نص اتصال كل مزود من مزودات قاعدة البيانات.. وهذه الفئات هي: 


الفئة وظيفتها 
1111111 إاإباني نص اتصال سيكويل سيرفر. 
51111111 بباني نص اتصال 01.11101. 
2511101 اباني نص اتصال 01(018)00. 
 OracleConnectionString Builder‏ باني نص اتصال أوراكل. 








اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 
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4 فئة باني نص الاتصال 
DbConnectionStringBuilder Class‏ 


هذه الففة موجودة في النطاق 5375]612.1(0318.0017711101؛ وهي تمثل واجهة 
القاموس راه" م!†ء5]ء مما يعني أنها مجموعة ]001160 كل عنصر من 
عناصرها يكون في صورة مفتاح رم وقيمة مں آج۷ .. وبهذا التصميم تستطيع 
ل بتكوين صيغة نص الاتصال بناء على هذه 
وتوجد هذه الفئة في نطاق الاسم «System.Data.Common‏ > لهذا لا تنس إضافة 
الجملة التالية أعلى صنفحة الكود قبل استخدامها: 
Imports System.Data.Common‏ 
ولحدث الإنشاء 5)10101م00) الخاص بهذه الفئة صيغتان: 
-١‏ الأولى لا تستقبل أي معاملات.. مثال: 
Dim CsB As New DbConnectionStringBuilder‏ 
؟- والثانية تستقبل معاملا منطقيا جهع8001»: اذا جعلت قيمته ع1[]” فسيتم 
مع مزود 8€ (0. 
وبالإضافة إلى خصائص القاموس الشهيرة» تمتلك هذه الفئة الخاصيتين التاليتين: 


و- نص الاتصال :ConnectionString‏ 
تقرأ أو تغير نص الاتصال الذي تتعامل معه هذه الفئة.. وتستطيع الحصول 
على نص الاتصال أيضا باستخدام الوسيلة ..ToString‏ لاحظ أن باني نص 


الاتصال يرتب المفاتيح في النص العائد حسب أولويتهاء وليس على حسب 
ترتيب إضافتك لها. 


وخ نص اتصال قابل للتصفح :BrowsableConnectionString‏ 
إذا حت قيمة هذه لاص ووا ف .عر طن تصن الا سل في دة 
الخصائص عندما تستخدم الأداة 610110م2:0 لعرض خصائص باني 
نص الاتصال: 

وبالإضافة إلى وسائل القاموس الشهيرة» تمتلك هذه الفئة الوسائل التالية: 

5 # إضافة مفتاح وقيمة :AppendKeyValuePair‏ 


١ 


تتيح لك إضافة خاصية وقيمتها إلى نص اتصال موجود في باني نص 
تن ت ومن 8+ حيبت سنقوم بنكرين الصيخة الصحيحة للخاصية رة 
ثم إضافتها في نهاية باني النص. 
وتستقبل هذه الوسيلة ثلاثة معاملات: : باني النص «StringBuilder‏ ونصا 
يمثل اسم الخاصية» ونصا يمثل قيمتها.. مثال: 
Dim SB As New System. Text.String Builder (‏ 
"Data Source = .\SQLEXPRESS;")‏ 
DbConnectionStringBuilder.AppendKeyValuePair(SB,‏ 
"AttachDbFilename'", "C:\Books.mdf"")‏ 
DbConnectionStringBuilder.AppendKeyValuePair(SB,‏ 
"Integrated Security'"", "True")‏ 
MsgBox(SB.ToString)‏ 
ستعرض الرسالة النص: 
Data Source = .\SQLEXPRESS; AttachDbFilename‏ 
C\Books.mdf; Integrated Security=True‏ = 
وتوجد صيغة أخرى لهذه الوسيلة» تزيد على الصيغة الأولى بمعامل رابع» إذا 
جعلت قيمته 1506» فسيتم وضع القيم بين قوسين متعرجين 1١‏ لاستخدام نص 
الاتصال مع مزود :01080. 


7# مسال ل :EquivalentTo‏ 

أرسل إلى هذه الوسيلة نسخة من الفئة DbConnectionStringBuilder‏ 
لمقارنتها بالنسخة الحالية من الفئة ..DbConnectionStringBuilder‏ وتتم 
ا أن كل مفتاح في القاموس الأول له ما يناظره في القاموس 
الثاني (بغض النظر عن الترتيب)» وأن القيمتين المحفوظتين في كليهما 
متساويتان. . لاحظ أن مقارنة المفاتيح لا تراعي حالة الأحرف. بينما مقارنة 
القيم تراعي حالة الأحرف.. وفي حالة نجاح المقارنة يعتبر نصا الاتصال 
الموجودين في القاموسين متساويين» وتعيد هذه الوسيلة مںإ1.. وستجد مثالا 
على ههه الوسيلة في الزر 180111972162610 في المشروع 
.ConStrBuilder‏ 


۳ 


#ا- هل يحتوي على 112112 510111015: 
تعيد عن[ إذا كان المفتاح الذي ارسلته إليها كمعامل موجودا ضمن نص 
الاتصال.. هذا معناه أن هذه الوسيلة مكافئة تماما للوسيلة /وع>20101481051.. 
وستجد مثالا على هذه الوسيلة في الزر 510111156112116 في المشروع 
.ConStrBuilder‏ 


7# محاولة معرفة القيمة e٤۷ [ue‏ ۷6إ: 
تحاول قراءة قيمة أحد المفاتيح الموجودة في نص الاتصالء فإن كان المفتاح 
موجودا أعادت ون1؛ وإن لم يكن موجودا أعادت 72196 دون أن تسبب 
خطأ في البرنامج.. لهذا يعتبر استخدامها أفضل من استخدام الخاصية 11670 
لقراءة قيمة المفتاح» فهي تسبب خطأ إن لم يكن المفتاح موجوداء مما يستلزم 
استخدام الوسيلة /وع>002181051 أولا على سبيل الاحتياط.. مثلا: 

If CSB.ContainsKey(" AttachDbFilename'"") Then 

MsgBox(CSB("'"AttachDbFilename'")) ' C:\Books.mdf 
End If 
وللوسيلة ماه 6۷ر۲٣ معاملان: الأول معامل نصي يستقبل اسم المفتاح»‎ 
والثاني معامل مرجعي 871164 من النوع 4+عنء[06» يعيد إليك قيمة المفتاح‎ 

إن وجد.. والكود التالي هو إعادة كتابة للمثال السابق باستخدام هذه الوسيلة: 
Dim Value As Object‏ 
If CSB.TryGetV alue("'AttachDbFilename'"", Value) Then‏ 

MsgBox(CSB('AttachDbFilename'")) ' C:\Books.mdf 
End If 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النار» وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 
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4 فنة باني نص اتصال سيكيول 
SqlConnectionString Builder Class‏ 


هذه الفئة ترث الفنة »D(bConnectionStringB u1] er‏ ويمكنك استخدامها لبناء 
نص الاتصال بسيكويل سيرفرء فهي تمتلك المزيد من الخصائص التي تحمل أسماء 
المعلومات اللازمة للاتصال بسيكويل سيرفرء مما يجعل تكوين نص الاتصال في 
منتهى السهولة والوضوح. 
ولحدث إنشاء هذه الفئة صيعتان: 

-١‏ الأولى بدون معاملات. 

؟- والثانية تستقبل نص اتصال لإضافته إليها مبدئياء حيث يمكنك إضافة أي 

تفاصيل أخرى إليه بعد ذلك. ش 


وبجوار ما ترثه من الفئة الأم» تمتلك هذه الفئة الخصائص التالية: 


5 توصيل ملف قاعدة البيانات ‘AttachDBFilename‏ 
تناظر المفتاح AttachDBFilename‏ أو name‏ 1516 10131ما في نص 
الاتصال.. ويمكنك أن تضع في هذه الخاصية مسار واسم الملف الأساسي 
لقاعدة البيانات التي تريد الاتصال بهاء وفي هذه الحالة سيتم توصيل هذه 
القاعدة بالخادم» والاتصال بها. 
وعليك أن تتأكد أن ملف قاعدة البيانات ليس للقراءة فقط 0115© ٥44‏ ۸» لأن 
توصيل قاعدة البيانات يحتاج إلى إنشاء ملف سجل الأداة ع1,0» واسمه يوضع 
في ملف قاعدة البيانات» ولو كانت للقراءة فقط فسيحدث خطأ ولن ينجح 
الاتصال. 
أيضاء قد يحدث خطأ إذا كان ملف سجل الأداء ع1,0] موجودا في مجلد قاعدة 
البيانات وأنت تحاول توصيلهاء مع وجود المفتاح 1(3]85356 في نص 
الاتصال.. فى هذه الحالة عليك حذف ملف سجل الأداء وإعادة الاتصال» 
حيث سيتم إنشاء سجل أداء جذيد لقاعدة البيانات. 


ا الفهرس الأساسي ع11111216'2162105: 
تقرأ أو تغير اسم قاعدة البيانات التي تريد الاتصال بها على الخادم.. وتختلف 
هذه الخاصية عن الخاصية السابقة في أنها تتعامل مع قاعدة بيانات متصلة 
بالخادم فعلا في هذه اللحظة:؛ لهذا يتم ذكر اسم قاعدة البيانات فقط بدون 
المسسر والامتداد (مثل “(Books‏ بينما في الخاصية 
ttachDB Filename‏ يتم ذكر مسار ملف قاعدة البيانات لتوصيلها بالخادم 
ثم الاتصال بها. 


وتناظر هذه الخاصية المفتاح 013850856 أو 0212108 101181 في نص 
الاتصال,:وقي الوضيع الإقتراضى كن قيمتها سا قرغا 


نآ مصدر البيانات عع:11ا22]8501: 
تقرأ أو تغير عنوان خادم سيكويل. . قديكون هذا العنوان للخادم المحلي 
5 ,أو لخادم بعيد R0 S٧٥۲‏ له عنوان بروتوكول 
الإنترنت 40101655 175 الخاص به مثل (10.0.0.127). 
وتناظر هذه الخاصية المفتاح Data Source‏ أو server‏ أو address‏ أو 
addr‏ أو network address‏ في نص الاتصال.. وفي الوضع الافتراضي 
تكون قيمتها نصا فارغا. 


“7 بديل فشل الاتصال erہ ¡[lover Pa)‏ ۴: 
تقرأ أو تغير عنوان خادم سيكويل البديل» الذي سيتم استخدامه إذا فشل 
الاتصال بالخادم الرئيسي الموضح في الخاصية السابقة. 
وتناظر هذه الخاصية المفتاح 221061 7311071 في نص الاتصال.. وفي 
الوضع الافتراضي تكون قيمتها نصا فارغا. 


وجا حماية متكاملة :IntegratedSecurity‏ 
تناظر المفتاح trusted connection‏ أو tegrated Security‏ في نص 
الاتصال. . وفي الوضع الافتراضي تكون قيمتها «False‏ مما يعني أن عليك 
إمداد الاتصال باسم المستخدم وكلمة المرور.. أما لو جعلت قيمتها 6نل”» 
بتم استخدام حساب المستخدم على الويندوز للاتصال.. هذا مفيد عند 
الاتصال بالخادم المحلي» أو عند استخدام البرنامج داخل شركة تستخدم شبكة 
داخلية ×1 فقي هذه الحالة يقوم مدير نظام سيكويل سيرفر 
System Administrator‏ بتعريف حسابات الويندوز الخاصة بأجهزة 
المستخدمين المتصلة بالشبكة والمسموح لها بالاتصال بالخادمء وبهذا يكفي 
مجرد تسبجيل الأخرل على الويندوز: لضمان سرية الانصال بالخادم. 


وخ معرف المستخدم (119111: 
تقرأ أو تغير اسم المستخدم الذي يتصل بالخادم» وذلك في حالة عدم استخدام 
الحماية المتكاملة .Integrated Security‏ 
وتناظر هذه الخاصية المفتاح (11 11561 أو 11561 أو 10نا في نص الاتصال.. 
وفي الوضع الافتراضي تكون قيمتها نصا فارغا. 


١55 


کلمة السر 0:ه22950: 
تقرأ أو تغير كلمة المرور اللازمة للاتصال بالخادم» وذلك في حالة عدم 
استخدام الحماية المتكاملة .Integrated Security‏ 
وتناظر هذه الخاصية المفتاح 23951010 أو لسم في نص الاتصال.. وفي 
الوضع الافتراضي تكون قيمتها نصا فارغا. 


معرف الجهاز :Workstation1‏ 
تقرأ أو تغير اسم الجهاز الذي يتصل بالخادم» وهي تناظر المفتاح 
Workstation 0‏ أو 775101 في نص الاتصال.. وفي الوضع الافتراضي 
تكون قيمتها نصا فارغا. 


يوتحم إبقاء معلومات السرية :PersistSecurityInfo‏ 
تناظر المفتاح Persist Security Info‏ أو 1110 في نص 
الاتصال.. وفي الوضع الافتراضي تكون قيمتها ©1219: مما يعني أن عليك 
إرسال اسم المستخدم وكلمة السر كلما أردت فتح الاتصال.. أما لو جعلت 
قيمتها 1”16؛ فيمكنك إرسال هذه المعلومات عند فتح الاتصال لأول مرة 
فقطء وسيتم الاحتفاظ بها لاستخدامها في فتح الاتصال بعد هذا. 


أ نفاد وقت الاتصال :ConnectTimeout‏ 
تمثل وقت الانتظار الذي ستعتبر محاولة الاتصال بالخادم فاشلة بعد مروره 
دون استجابة من الخادم» وهي تناظر المفتاح Connect Timeout‏ أو 
connection timeout‏ أو timeout‏ في نص الاتصال.. وفي الوضع 
الافتراضي تكون قيمتها ٠١‏ ثائية. 


وخ اسم التطبيق eصApplicationNa:‏ 
تناظر المفتاح مم2 أو هآ 11031052ممى في نص الاتصال.. وفي 
الوضع الافتراضي تكون قيمتها ›.NNET 5010114 Data Provider‏ لکن 
بإمكانك أن تضع فيها اسم برنامجك. 


أ اللغة الحالية :CurrentLanguage‏ 
تق رأأو تة تغير اسم سجل اللغة في سيكويل سيرفرء وهي تناظر المفتاح 
language‏ أو Current language‏ في نص الاتصال.. وفي الوضع 
الافتراضي تكون قيمتها نصا فارغا "". 


€۷ 


وخ التشفير 101119704: 
تناظر المفتاح 1م1157 في نص الاتصال.. وفي الوضع الافتراضي تكون 
قيمتها 1156 مما يعني أن خادم سيكويل لن يشفر البيانات المرسلة بينه وبين 
العميل.. ولو جعلت قيمتها 1516 » فسيتم استخدام نوع من التشفير يسمى 
0 55152 الذي يعني "تشفير طبقة مقابس الاتصال الآمنة" 
Secure Sockets Layer Encryption‏ وهو يستخدم مفتاحين: مفتاحا 
عاما Key‏ ع1[طن© يستخدم لتشفير البيانات» ومفتاحا خاصا Private Key‏ 


ال إجازة خادم موثوق ڊ4 :TrustServerCertificate‏ 
تناظر المفتاح ع11015561576100610111026' في نص الاتصالء وإذا جعلت 
قيمتها عuإ1»‏ فسيتم تجاهل عملية إجازة الخادم 0611220100» اكتفاءً 
بحماية البيانات باستخدام تشفير 551. 


"ل اتصال بالمحتوى 076)1012 04600 ©: 
تناظر المفتاح 00026110 Context‏ في نص الاتصال.. وفي الوضع 
الافتراضي تكون قيمتها ©1"215. 
وينصح بجعل قيمة هذه الخاصية عuآ1‏ عند الاتصال بخادم محلي 
Server‏ 1.0081 توجد عليه الإجراءات المخزنة ودوال ,7-5001 التي تريد 
تنفيذهاء لأن هذا يجعلك تستخدم نفس موارد الاتصال السابق بالخادم المحليء 
مما يوفر عليك إعادة إدخال اسم المستخدم وكلمة السرء ويتيح لك التفاعل مع 
التعاملات 15325301005 التي لم يتم حفظها بعد» كما يتيح لك استخدام 
الجداول المؤقتة التي تم إنشاؤها على الاتصال المحلي.. وتؤدي هذه الطريقة 
إلى أداء أفضل للبرنامج» لأنها تتجاهل بروتوكولات الشبكة ومراحل نقل 
البيانات عبرهاء وتتعامل مباشرة مع الخادم المحلي (لأنه يوجد على نفس 
الجهاز)» مما يجعل الاتصال أسرع وأكفا. 
وينصح بجعل قيمة هذه الخاصية »782156 لاستخدام الاتصال العادي 21[ناعع*1 
0 ؛ وذلك عند الاتصال بخادم بعيد (غير محلي) Remo‏ 
.Server‏ 
والشكل التالي يلخص الفارق بين هذين النوعين من الاتصال.. لاحظ أن 
الاتصيدال بالمستوى جال اليد سن طقات الاتصال عيبيو التنيقة 
»Network) Layers‏ ويس تخدم واجهة الاتصال المباشر 
.In-Process Interface‏ 
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Application programming interface (AP1I) layer | 
(public API, high-level validation and policy) 


Context Regular 
connection connection 


Client-side protocol layer 
(TDS-SQL Server protocol) 


: 


Client-side transport layer 
(TCP, Named Pipes, and so on) 


Client 
(inside or outside In-process 
the server) interface 
Server 


Server-side transport layer 
(TCP, Named Pipes, and so on) 


+ 


Server-side protocol layer 
(TDS-SQL Server protocol) 


1 


( SQL Server Database Engine 


في القائمة ونام ع: 
تناظر المفتاح 181156 في نص الاتصال.. وفي الوضع الافتراضي تكون 
قيمتها 10؛ مما يعني أن الاتصال الحالي سيوضع في قائمة الاتصالات 
المستخدمة لمحتوى التعاملات الحالي ..Current Transaction Context‏ 


بحيث لو فشلت أي عملية على أي اتصال منها يتم إلغاء العمليات التي تمت 
على باقي الاتصالات.. لن نتعمق في موضوع التعاملات 1723153611055 في 
هذا الكتاب» وسنتعرف عليه مع باقي المواضيع المتقدمة في برمجة قواعد 
البيانات في الكتاب القادم بإذن الله. 


وخ معالجة غير متزامنة عدزووءعع02011511:0تط459:0: 

تناظر المفتاح 259700 أو Asynchronous Processing‏ في نص 
الاتصال.. وفي الوضع الافتراضي تكون قيمتها ع1215» ولو جعلت قيمتها 
م فسيعني هذا السماح للخادم بإجراء عمليات معالجة غير متزامنة.. هذا 
معناه أن برنامجك سيواصل العمل مباشرة بعد إرسال الاستعلام إلى الخاد 
تاركا الخادم يواصل تنفيذ الاستعلام.. هذا يوفر عليك كتابة الكثير من الكود 
لإنشاء عمليات فرعية 1516205 أو عمليات غير متزامنة فى برنامجك 
لضمان مواصلة الاستجابة للمستخدم أثناء معالجة سيكويل سيرفر 
للامتعاحات السبائقة. 
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3 مساهمة ع20011: 
تناظر المفتاح 2001108 في نص الاتصال.. وفي الوضع الافتراضي تكون 
يميا وآ :مها تس أن :هذا الاتصال تنك إلى رصدالاك الات 
المساهمة 172001 0025260102 التي تظل مفتوحة دائما لاستخدامه فور 
الحاجة إليها.. أما لو جعلت قيمتها 12156 فسيعني هذا أن هذا الاتصال سيتم 
فتحه وإغلاقه مباشرة بعد انتهاء استخدامه» وعند الاحتياج إليه مجددا يتم فتحه 
من جديد.. وهكذا. 


وخ أقصى حجم للمساهمة 001526 112512: 
تناظر المفتاح Max Pool Size‏ في نص الاتصال.. وفي الوضع الافتراضي 
تكون قيمتها ٠٠١‏ مما يعني الاحتفاظ في رصيد الاتصالات المساهمة 
المتاحة للاستخدام» بمئة اتصال ‏ كحد أقصى - مفتوحة بين الخادم والعميل. 


3 أقل حجم للمساهمة :MinPo01Size‏ 
تقرأ أو تغير أصغر عدد من الاتصالات يجب أن يظل مفتوحا بين الخادم 
والعبيل فى رحبي الاتضعاات البساحنة وفي تتاظر الاع 
Min 2001 Size‏ في نص الاتصال.. وفي الوضع الافتراضي تكون قيمتها 


وخا وقت انتظار توازن الحمل :LoadBalance Timeout‏ 

تقرأ أو تغير الوقت بالثانية» الذي يتم انتظاره أثناء وجود الاتصال في رصيد 
الاتصالات المساهمة 72001 2611052م00» قبل أن يتم إغلاق الاتصال» 
وذلك لضمان عدم ترك الاتصالات المفتوحة خاملة بدون استخدام لفترات 
طويلة.. وفي الوضع الافتراضي تكون قيمتها صفراء مما يعني ترك الاتصال 
مفتوحا دائما بدون قيود. 

وتناظر هف الخاصية المفقاح عصt1م11f connection‏ 
أو Balance Timeout‏ 1.030 في نص الاتصال. 


ا إعادة الاتصال إلى وضعه الأصلي :Connection Rese‏ 
تناظر المفتاح Rese)‏ 00261102) في نص الاتصال.. وفي الوضع 
الافتراضي تكون قيمتها 156؛ وهذا معناه أن الاتصال سيعود إلى وضعه 
الأصلي عند طلب استخدامه من رصيد الاتصالات المساهمة 
.Connection Pool‏ 


3 مجموعات النتائج الفعالة المتعددة :MultipleActive ResulSets‏ 
تناظر المفتاح Multiple ActiveResu|)Se†s‏ في نص الاتصال.. وفي 
الوضع الافتراضي تكون قيمتها 172156: وهذا معناه استخدام "مجموعة النتائج 
العادية" Resul) Se‏ {اD(efau»‏ وفيها يتم إرسال نتائج الاستعلام من خادم 
سيكويل إلى جهاز العميل» حيث يتم حفظها في مخزن وسيط 811101 في 
الذاكرة» وعندما يحتاج برنامجك إلى عرضها للمستخدم» يتم المرور عبرها 
سجلا بسجل.. ولا يستطيع العميل استخدام الاتصال المفتوح مع الخادم في 
تحديث البيانات قبل أن ينتهي من التعامل مع كل البيانات التي أرسلها الخادم 
أولاء أو قبل أن يرسل إلى الخادم طلبا لإلغاء إرسال باقي النتائج.. وتعتبر هذه 
الطريقة أكثر كفاءة في استغلال الاتصال» لأن الخادم يرسل أكبر كم ممكن 
من النتائج عبر حزم البيانات 5+عع[ع2 المرسلة عبر الشبكة kإNetwo.‏ 
ولو جعلت قيمة هذه الخاصية مںu]؛‏ فسيتم استخدام "مجموعات النتائج 
الفعالة المتعددة" Multiple Active Result Sets‏ أو اختصارا 21/4195 
وهي متاحة فقط مع سيكويل سيرفر ٠٠١5‏ وما يليه من إصدارات» وفيها 
يسمح للعميل باستخدام أكثر من قارئ بيانات 5011032163061 في نفس 
الوقت. 


وخا مكتبة الشبكة :NetworkLibrary‏ 
ضع في هذه الخاصية اسم مكتبة الربط 111 التي تريد من الخادم استخدامها 
للاتصال عبر الشبكةء وذلك بشرط توفر هذه المكتبة على الخادم. 
وتناظر هذه الخاصية المفتاح Network Library‏ أو network‏ أو net‏ في 
نص الاتصال.. وفي الوضع الافتراضي تكون قيمتها نصا فارغا.. والجدول 
الال يوضم الى السا لهذه الخاضصية 


اسم مكتبة الربط نوع الاتصال 
Named Pipes dbnmpntw‏ 
Multiprotocol dbmsrpcen‏ 
AppleTalk dbmsadsn‏ 
VIA dbmsgnet‏ 
Shared Memory dbmslpcen‏ 
IPX/SPX dbmsspxn‏ 
TCP/IP dbmssocn‏ 






































وف حال الال مع كناف سطلي وارك فم هذه القاصية فار كيت 
استخدام المكتبة 0م0051 .(Shared Memory)‏ 


وخا حجم حزمة البيانات 221]5[26: 
عند إرسال البيانات عبر الشبكة أو الإنترنت» يتم تقسيمها إلى حزم 
115 . وتحدد هذه الخاصية حجم كل حزمة من هذه الحزم بالوحدة 
الثنائية م)ر8؛ وفي الوضع الافتراضي تكون قيمتها ۸٠٠٠١‏ وحدة عالا8. 
وتناظر هذه الخاصية المفتاح 5176 )ءج في نص الاتصال. 


3 النسخ المطابق :Replication‏ 

تناظر المفتاح 161102110 في نص الاتصال.. وفي الوضع الافتراضي 

تكون قيمتها »21215 وإذا جعلتها 11 فسيتم تمكين عملية النسخ المطابق 

Replication‏ عبر هذا الاتصال» وهي تقنية آلية تتيح لك نسخ قاعدة بيانات 
بين أكثر من خادم» وإبيقاء البيانات متزامنة بين الخادمين» بحيث يتم تحديث 

ا قاعدتي البيانات إذا حدث تغيير في الأخرى.. هذا مفيد عندما يكون 

هناك خادم أصلي وخادم احتياطي للتعامل معه إذا حدثت مشكلة في الخادم 

الأصلي أو تم إيقافه للصيانة مثلا. 


و- ربط التعاملات :TransactionBinding‏ 
تناظر المفتاح ¡nding‏ 1305302" في نص الاتصال.. ويمكنك أن 
تضع فيها إحدى القيمتين التاليتين: 

1110 1161مدم1] | فك ارتباط ضمني: وهي القيمة الافتراضية» وفيها 
يؤدي إغلاق الاتصال إلى فصله عن التعاملات 
الجارية .Current Transactions‏ 
Explicit Unbind‏ | فك ارتباط صريح: يجب عليك فك الارتباط بين 
الاتصال والتعاملات الجارية بطريقة صريحة قبل 
إغلاق الاتصالء وإلا حدث خطأ. 











وخ إصدار نظام الأنواع :TypeSystem Version‏ 
تناظر المفتاح 1761510 Systm‏ 6م157 في نص الاتصال» وهي تتيح لك 
تحديد إصدار سيكويل سيرفر الذي تريد أن تستخدم أنواع البيانات الخاصة 
به.. على سبيل المثال» لو كان الخادم يستخدم سيكويل سيرفر ۸٠۲۰ء‏ وجعلت 
قيمة هذه الخاصية2000 +5176 ,501» فيمكنك استخدام أنواع البيانات 
5 هه( الخاصة بسيكويل سيرفر ۰٠۲۰۰۰‏ حيث سيقوم سيكويل سيرفر 
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القيم الممكنة لهذه الخاصية: 


7 501 | يتم استخدام الأنواع الخاصية بسيكويل سيرفر ..٠٠٠١‏ 

إصدارات أحدث؛ مثل: 

.NTEXT إلى‎ XML تحويل‎ - 

.VARBINARY إلى‎ ODT تحويل‎ - 

.TEXT إلى‎ VARCHAR(M۸AX) تحويل‎ - 

.NEXT إلى‎ NVARCIHAR(MAX) Jıgحت‎ - 

.IMAGE إلى‎ ARBINARY(MAX) تحويل‎ - 

00 يتم استخدام الأنواع الخاصية بسيكويل سيرفر‎ SQL Server 
2005 

۰۸ يتم استخدام الأنواع الخاصية بسيكويل سيرفر‎ SQL Server 
2008 
يتم استخدام أحدث إصدار من سيكويل سيرفر يمكن‎ Latest 

للخادم والعميل التعامل معه. 

وخا نسخة المستخدم :UserInstance‏ 

تناظر المفتاح 1251206 17561 في نص الاتصال.. وفي الوضع الافتراضي 

تكون قيمتها »1215: ولو جعلتها 151 فسيتم توجيه الاتصال من نسخة خادم 

سيكويل الافتراضية» إلى نسخة أخرى مخصصة للعميل» لكن هذا قد يسبب 

أخطاء في الاتصال إذا كنت تستخدم السمة 71158151101417 لحفظ بيانات 

بعض الأعمدة في ملفات خارجية. 











ولا تمتلك هذه الفئة أية وسائل 741615005 غير ما ترثه من الفئة الأم. 

والمثال التالي يريك كيف تستخدم هذه الفئة لتكوين نص اتصال بقاعدة الكتب على 
الخادم المحلي باستخدام الحماية المتكاملة: 

Dim CnStrBldr As New SqlConnectionStringBuilder 
CnStrBldr.DataSource = ".\SQLEXPRESS" 
CnStrBldr.InitialCatalog = "Books" 
CnStrBldr.IntegratedSecurity = True 
Dim CnStr = CnStrBldr.ConnectionString 
MsgBox(CnStr) 





\or 

















عند كتابة برنامج يتعامل مع قواعد البرنامج» يلجأ المبرمج في معظم الأحول إلى 
إنشاء قاعدة البيانات على جهازه» أو ينسخ جزءا من قاعدة البيانات من الخادم إلى 
جهازه» ليجعلها تعمل على الخادم المحلي» ومن ثم يتصل بها من برنامجه.. هذا 
يجعل كتابة واختبار الكود وتصحيحه أسرع من التعامل مع خادم حقيقي عبر شبكة 
الإنترنت» كما أنه يضمن عدم تخريب قاعدة البيانات الرئيسية عند إضافة أو حذف 
وبعد الانتهاء من البرنامج» يتم رفع قاعدة البيانات الىئ الخادم 
(إن لم تكن موجودة عليه)» وتصحيح نصوص الاتصال لتشير إلى الخادم الحقيقي 
بدلا من الخادم المحليء لكي يبدأ البرنامج عمله في صورته النهائية. 
ونظرا لأن البرامج العملية قد تتعامل مع أكثر من قاعدة بيانات» كما أن عنوان 
قاعدة البيانات قد يتغير في أي لحظة لو تم نقلها من خادم إلى آخر على الإنترنت» 
يصير من غير العملي كتابة نص الاتصال في الكودء لأن البحث عنه وتغييره في 
كل المواضع أمر مرهق وعرضة للخطأ.. لهذا يفضل كتابة نصوص الاتصال في 
(كاسم المستخدم وكلمة السر).. ويمكن فعل هذا يدوياء أو باستخدام إحدى الطرق 
الجاهزة التي تمنحها دوت نت» كالإعدادات Settings‏ التي تعرفنا عليها بالتفصيل 
الممل في مرجع "برمجة نماذج الويندوز"» وقلنا هناك إن دوت نت تقدم رعاية 
خاصة لنصوص الاتصال» فقد خصصت لها مقطعا خاصا في ملف الإعدادات» 
ومنحتنا فئة تتعامل معه» هي الفئة 00260110511185566160.. ولقد أرجأنا 
شرح هذا الموضوع إلى حين التعرف على قواعدء وها نحن أولاء © . 
لإضافة نص اتصال إلى الإعدادات بطريقة مرئية اتبع الخطوات التالية: 
- افتح متصفح المشاريع 10161م1 901102» وانقر مرتين بالفأرة فوق 
العنصر ]ع220[6 ..[y‏ سيؤدي هذا إلى فتح نافذة خصائص المشروع. 
- اضغط العنصر 5611285 من الهامش الأيسر لفتح صفحة مصمم الإعدادات 
كما تعلمنا من قبل. 
- في العمود مه" اكتب اسم خاصية الإعداد« ولتكن خ80015)0051. 
- في العمود مرآ اضغط زر الإسدال» ومن القائمة المنسدلة اختر العنصر 
الخاص (ع ماك 02اعءعممه0).. هذا سيغير نطاق خاصية الإعداد 
Scope‏ ليصير على مستوى التطبيق 116216101ممىل. 
- اضغط الزر الموجود في خانة القيمة 172116. . سيعرض لك هذا مربع حوار 
خصائص الاتصال الذي استخدمناه من قبل لإنشاء اتصال من متصفح 
الخوادم :وع:10م:1 هزع 9.. هذا يتيح لك تكوين نص الاتصال بطريقة 
مرئية سهلة.. حدد مزود البيانات وقاعدة البيانات واختيارات الحماية.. ولو 
أردت استخدام المزيد من مفاتيح نص الاتصالء فاضغط الزر 
..A vanced‏ سيعرض لك هذا النافذة التالية: 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


[Advanced Properties 


كيه 
MultipleActiveResultSet False‏ 
Network Library‏ 
KESE‏ 
Transaction Binding Implicit Unbind‏ 
Type System Version Latest‏ 


Application Name „.Net SqIClient Data Provic 
Workstation ID 





Asynchronous Processit 


























هذه النافذة تعرض خصائص نص الاتصال» وهي نفس الخصائص التي 
شرحناها في الفئة 131011161ع1402511108ع50100226.. ويمكنك تغيير القيم 
الافتراضية لهذه الخصائص» وكل خاصية ستغيرها ستظهر في نص 
الاتصال الذي سيتم تكوينه. 

- اضغط 0K‏ لإغلاق النافذتين.. سيظهر نص الاتصال الذي تم تكوينه في 
الخانة مu‏ اج۷ . 

- وإذا كنت تحتاج إلى هذاء يمكنك إضافة نصوص اتصال أخرى إلى 
الإعدادات» بالكتابة في الصفوف التالية وبهذا تجمع في مكان واحد» كل 
نصوص الاتصال اللازمة للتعامل مع كل قواعد البيانات والخوادم التي 
تحتاجها في برنامجك» مما يسهل عليك تعديلها في أي لحظة. 

- اضغط زر الحفظ من شريط الأدوات لحفظ هذه التغييرات في ملف إعدادات 
المشروع. 


الآن» تم توليد خاصية اسمها 800150051 في فئة الإعدادات وعم)]ء5 في 
النطاق ‘My‏ وتسد تستطيع قراءة قب قيمتها في أي وقت بمنتهى البساطة.. جرب مثلا* 
MsgBox(My.Settings.BooksConStr)‏ 


لاحظ أنك لا تستطيع تغيير قيمة الخاصية خ80015)'05 لأنها معرفة للقراءة 
فقطء لكن ما زال بوسعك فتح مصمم الإعدادات في أي لحظة لتغيير قيمة نص 
الاتصالء أو فتح الملف عاگمهء.م مه من متصفح المشاريع» وتحرير قيمة 
الخاصية Books 0S۲‏ التي ستجدها تحت المقطع «<connectionStrings>‏ 
دون الحاجة إلى تغيير أي كود في برنامجك. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النار» وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


5 فئة مقطع نصوص الاتصال 
ConnectionStringsSection Class‏ 


هذه الفئنة موجودة في النطاق ١10ا‏ uعاÊصه٣.صSystem»‏ وهي ترث الفئنة 
Section‏ التي تعرفنا عليها في كتاب برمجة الويندوز. 
ولا جديد في هذه الفئةء سوى امتلاكها للخاصية التالية: 


7 ف نصوص الاتصال :ConnectionStrings‏ 
تعيد مجموعة من gill‏ ع ›ConnectionStringSettingsCollection‏ التي 
ترث الفئة »ConfigurationElementCo|lection‏ وکل عنصر من 
عناصر هذه المجمورعة هومن نوع فئفة إعنداذات نص الاتصال 
»C0nnectionStringSettings Class‏ التي سنتعرف عليها بعد قليل. 
وتتيح لك هذه المجموعة قراءة كل نصوص الاتصال الموجودة في ملف 
الإعدادات. 


ويمكنك استخدام إحدى وسائل فتح التهيئة ٣10اوإenxxConfiguم0p‏ الخاصة 
بمدير التهيئنة عع 1:21021/1318ناع 00145 للحصول على كائن تهيئة 
Configuration Object‏ يتعامل مع النوع المراد من الإعدادات» ثم استخدام 
الخاصية 55 001260110151110 لكائن التهيئة للحصول على نسخة من الفئنة 
10 كالتالي: 
Dim Cnfg = ConfigurationManager.OpenMachineConfiguration‏ 
Dim CnStrSett = Cnfg.ConnectionStrings‏ 


7# فئة إعدادات نص الاتصال 
ConnectionStringSettings Class‏ 


هذه الفئة ترث فئة عنصر التهيئة 1255© Configuration Ele men)‏ التي تعرفنا 
عليها في كتاب برمجة نماذج الويندوز. 
ولحدث إنشاء هذه الفئة ثلاث صيغ: 
-١‏ الأولى بدون معاملات. 
-١‏ والثائية تستقبل معاملين: اسم خاصية الإعداد التي ستحفظ نص الاتصال؛ 
ونص الاتصال نفسه. 
#د.والقالثة تز يك على الصيغة النائقة بمعائل فالنك» بقل اسم مز وة البياكانت 
:101 الذي سيستخدم نص الاتصال. 
وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخصائص التالية: 


وخ الاسم :Name‏ 
تقرأ أو تغير اسم خاصية الإعداد التي ستحفظ نص الاتصال. 


وخ نص الاتصال :ConnectionString‏ 
تقرأ أو تغير نص الاتصال المحفوظ في خاصية الإعداد. 


وخ اسم المزود :ProviderName‏ 
تقرأ أو تغير اسم مزود البيانات الذي سيستخدم نص الاتصال. 


ويه كنك الحص ول غل مجموعة إعدادات نصوص الاتصال الخاصة بالتطبيق» 
باستخدام الخاصية المشتركة /جّءع م220 513160 التالية: 


Dim CnStrSett = ) 111510110012112 1.) 2265‏ 
والمثال التالي يعرض لك كل نصوص الاتصال الموجودة في ملف إعداد التطبيق: 





Dim CnStrSett = ConfigurationManager.ConnectionStrings 

For Each CnStr As ConnectionStringSettings In CnStrSett 
MsgBox(CnStr.Name) 
MsgBox(CnStr.ProviderName) 
MsgBox(CnStr.ConnectionString) 

Next 


ملحوظة: 

يجب عليك حماية نص الاتصال بتشفيره» وذلك لأن ملف الإعدادات يتم توزيعه مع 
البرنامج» مما يجعل المستخدمين قادرين على قراءته وأخذ كلمات المرور منه. 
ويمكنك تشفير مقطع نصوص الاتصال <0010601100511185)> في ملف 
الإعدادات: ينف الطريقة التي شرحتاها. في كتاب يزمجة الويتدوز» واستحدمتاها 
في البرنامج وع12)]اء 5م4004 المرفق بذلك الكتاب. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 














© واجهة الاتصال بقواعد البيانات 
IDbConnection Interface‏ 


هذه الواجهة تمثل الواجهة ©11(15005211» وهي تتيح لك إنشاء كائن اتصال خاص 
بك» وذلك بكتابة فة تمثلها 10111206 the‏ ementsاmp]..‏ هذا يسهل عليك 
كتابة مزود جديد للتعامل مع نوع معين من قواعد البيانات غير متاح في إطار 
العمل. 

وتمتلك الواجهة 110ع11(500016 الخصائص التالية: 


3 نص الاتصال :ConnectionString‏ 
تقرأ أو تغير نص الاتصال الذي يحتوي على المعلومات اللازمة للاتصال 
بقاعدة البيانات.. ولا يمكنك تغيير قيمة هذه الخاصية إلا عندما يكون الاتصال 
مع قاعدة البيانات مغلقا. 


وق وقت الانتظار ‘Connection Timeout‏ 
تقبل عددا صحيحاء يمثل الوقت بالثانية» الذي سيتم انتظاره أثناء محاولة 
الاتصال بقاعدة البيانات» فإذا مر هذا الوقت دون أن يستجيب الخادم» يتم إلغاء 
العملية وينطلق خطأ في برنامجك.. والقيمة الافتراضية لهذه الخاصية هي ١5‏ 
ثانية» لكن إذا أردت أن تظل منتظرا إتمام الاتصال إلى ما لانهاية» فضع 
صفرا في هذه الخاصية!. اوري ا 
إذا فشلت عملية الاتصال بالخادم» لهذا لو استخدمت هذه القيمة فيجب أن 
تعطي للمستخدم طريقة لإلغاء محاولة الاتصال بنفسه»ء كأن تضع على 
النموذج زر إلغاءء مع جعل عملية الاتصال في عملية فرعية مستقلة 20عتط]1' 
لكي لا يتوقف البرنامج عن الاستجابة. 
لاحظ أن وضع قيمة كبيرة في هذه الخاصية سيؤدي إلى تعطيل البرنامج لفترة 
أطول» ووضع قيمة صغيرة فيها سيؤدي إلى فشل محاولات الاتصال 
بسرعة.. وأفضل قيمة لهذه الخاصية هي ما تراه مناسبا لظروف برنامجك.. 
فلو كنت تتوقع ضغطا كبيرا على الخادم يجعل استجابته لمحاولات الاتصال 
بطيئة أو متأخرة» فضع قيمة أكبر في هذه الخاصية (مثل 50 أو 1٠١0‏ مثلا). 


7 ف قاعدة البيانات 12262256: 
تيد اسم قاعدة البيانات التي يتم الأتصال بها 


57 فور الحالة ع5)21: 
تعيد إحدى قيم المرقم ع001611025121) التي تعبر عن حالة الاتصال في 


10 اتم إغلاق الاتصال. 

Open‏ الاتصال مفتوح. 
Connecting‏ | يتم إجراء الاتصال. 
Executing‏ يتم تنفيذ أحد الأوامر على قاعدة البيانات عبر الاتصال 
الحالي. 
۴th‏ | يتم إحضار بيانات من قاعدة البيانات عبر الاتصال الحالي. 
Broken‏ تم فتح الاتصال» لكن حدث عطل أدى إلى إغلاقه.. ويمكنك 
إعادة محاولة فتح هذا الاتصال. 











كما تملك .هذة الواحية الوسائل القالية: 


7# فتح برعم 0: 
تفتح الاتصال بقاعدة البيانات» تبعا للبيانات الموجودة في الخاصية 
.ConnectionString‏ 


# تغيير قاعدة البيانات مChangeDatabas:‏ 
أرسل إلى هذه الوسيلة معاملا نصياء يمثل اسم قاعدة بيانات جديدة موجودة 
على نفس الخادم» للتعامل معها بدلا من قاعدة البيانات الحالية الموضحة في 
الخاصية 1(386356.. لاحظ أن استخدام هذه الوسيلة متاح فقط أثناء فتح 
الاتصال بالخادم» وإلا حدث خطأ يخبرك أن الاتصال مغلق!.. الحكمة من 
هذاء هو استغلال نفس الاتصال المفتوح مع الخادم للتعامل مع أكثر من قاعدة 
بيانات» لتوفير وقت إغلاق الاتصال وإعادة فتح اتصال جديد. 


# إنشاء أمر :CreateCommand‏ 

تنشئ هذه الوسيلة كائن أمر زا0 001:31810©) جديد لتنفيذه عبر كائن 
الاتصال الحالي.. ولا يشترط أن يكون الاتصال مفتوحا عند استدعاء هذه 
الوسيلة» فكل ما تفعله هو إنشاء كائن أمر مناسب» ووضع مرجع لكائن 
الاتصال الحالي في الخاصية 026110" الخاصة بكائن الأمر.. لكن عند 
قفي الأمن يحبا أن بكرن الاتصيال مف حا فعا وال حدث خطا 

والقيمة العائدة من هذه الوسيلة من نوع واجهة "أمر قاعدة البيانات" 
4 التي سنتعرف عليها بالتفصيل لاحقا. 


15١ 























0 بدء التعاملات :BeginTransaction‏ 

تنشئ هذه الوسيلة كائن تعاملات ]ع ءز0 15352014102 لتستطيع من خلاله 
إجراء عدد من العمليات علس قاعدة البيانات» مع قدرتك غل التراجع عنها 
بعد ذلك.. والقيمة العائدة من هذه الوسيلة من نوع واجهة "تعاملات قاعدة 
البيانات" 1101135314101 التي سنتعرف عليها بالتفصيل لاحقا. 

وتوجد صيغة ثانية لهذه الوسيلة» لها معامل واحد يستقبل إحدى قيم المرقم 
"مستوى العزل" 190131011.6761.. وسنتعرف على هذا المرقم بالتفصيل 
لاحقا. 


2# إغلاق »105©: 

تقوم بالتراجع ع1ع120110 عن أي تعاملات 718253141005 لم يتم إحالتها 
إلى قاعدة البيانات إع)انسصصه).. ثم تغلق الاتصال. 

لاحظ أنه في حالة تفعيل خاصية المساهمة عزآ1ه50» فإن خادم سيكويل 
يحافظ على عدد محدد من الاتصالات المفتوحة بينه وبين برنامجك» وذلك 
لتوفير وقت إغلاق وإعادة فتح الاتصالات بينهما.. وفي هذه الحالة لا تقوم 
الوسيلة 01056) بإغلاق الاتصال» بل تترك الاتصال مفتوحاء وتضيفه إلى 
رصيد الاتصالات المساهمة 72001 001161105» ليمكن استخدامه مباشرة 
عند الاحتياج إليه. 


1۲ 


DbConnection Class فئة الاتصال‎ 42 


هذه الفئة أساسية مجردة «Abstract Base Class‏ تجب وراثتها «MustInherit‏ 
وهي تمثل الواجهة 11(5001261101» كما أنها ترث فة المكون Component‏ 
و5 » لكنك لن تستطيع إضافتها إلى صينية مكونات النموذج Component‏ 
وو لأنك لا تستطيم إنشاء فسخة جديدة منهة لكق الات المشككة منها مكل 
101 يمكن إضافتها إلى صينية المكونات.. لفعل هذا افتح صندوق 
الأدوات ‘Toolbox‏ وأسدل الشريط و5 واضغطه بزر الفأرة الأيمن» ومن 
القائمة الموضعية اضغط «Choose Items‏ وفي النافذة التي ستظهر› ضع علامة 
الاختيار بجوار مجموعة الأدوات التي تبدا بالحروف ,5001 ومن ضمنها 
10 ثم اضغط الزر 0.. الآن ستجد هذه الأدوات تحت الشريط 
08 في صندوق الأدوات.. انقر الأداة م10)ععممه5010 مرتين بالفأرة 
لإضافة نسخة منها إلى صينية المكونات. 

وبالإضافة إلى ما تمثله من خصائص الواجهة 110ع11(00026» تملك هذه الفئة 
الخاصيتين التاليتين: 


7 ف مصدر البيانات :5a)4S0u ce‏ 
تعيد اسم خادم سيكويل الذي سيتم الاتصال به. 


7 فز إصدار الخادم :ServerVersion‏ 
تعيد نصا يمثل إصدار سيكويل سيرفر الذي يتصل به العميل.. ويجب أن 
يكون الاتصال مفتوحا في تلك اللحظة وإلا حدث خطأ. 


وبالإضافة إلى ما تمثله من وسائل الواجهة 11(000216©110» تمتلك هذه الفئة 
الوسيلتين التاليتين: 


7# إضافة إلى قائمة التعاملات :EnlistTransaction‏ 
أرسل إلى هذه الوسيلة كائن التعاملات )عو ز0 7885301105 الذي تريد 
ق انات لاقمل الحا اله ارين الات رة 
»D¡stributed Transaction‏ وهي تعاملات تنفذ عمليات على أكثر من 
مصدر وأكثر من اتصالء ولا ينجح تنفيذها إلا إذا نجحت كل أجزائها.. 
وسنتعرف على كائن التعاملات لاحقا. 


2# معرفة المخطط وَرررعراء6)5©: 


1۳ 


تعيد كائن جدول 06[601 1(2181816: يحتوي على بيانات المخطط الخاص 
بالخادم. 


ولهذه الوسيلة صيغة ثانية» تستقبل معاملا نصيا يمثل اسم المخطط الذي تريد 
استعادته. 
كما توجد صيغة ثالثة» تزيد على الصيغة السابقة بمعامل ثان» يستقبل مصفوفة 
نصية 41237 عم5» تمثل القيود 126511101005 التي تريد الحصول على 
مخططها. 


كما تمتلك هذه الفئة الحدث التالي: 


2 تغير الحالة :StateChange‏ 
ينطلق عند تغير حالة الاتصال (عند إغلاقه أو فتحه).. والمعامل الثاني م لهذا 


لحدث من النوع وع eEven)AعStateChang»‏ وهو يمتلك الخاصيتين 
التاليتين: 


5 بو | 15121 دمع 0 ١‏ تعيد إحدى قيم المرقم ConnectionState‏ 
التي تمثل حالة الاتصال قبل حدوث التغيير. 

5 بهن | CurrentState‏ | تعيد إحدى قيم المرقم ConnectionState‏ 
التي تمثل حالة الاتصصال الحالية 
(بعد حدوث التغيير). 














والفئات التالية ترث الفئة :DbConnection‏ 

.SqlConnection .١ 

.OdbcConnection ؟.‎ 

.OleDbConnection ." 

.OracleConnection .“‏ 
مما يعني أنها جميعا تمتلك خصائص ووسائل هذه الفئة.. وسنتعرف الان على 
واحدة من هذه الفئات» وهي الفئة .SqlConnection‏ 


1٤ 











4 فئة اتصال سيكيول SqIConnection Class‏ 


هذه الففة ترث الفئة 101 ممما يعني أنها ضمنيا ترث الفئة 
Component‏ وتمثل الواجهة .IDbConnection‏ 

وبالإضافة إلى الخصائص التي ترثها من الفئة الأم» تمتلك هذه الفئة الخصائص 
التالية: 


3 إطلاق حدث الخطأ :FireInfoMessageEventOnUserErrors‏ 
إذا جعلت قيمة هذه الخاصية مں ٠۲۲‏ فسيتم إطلاق الحدث InfoMessage‏ 


في البرنامج عند حدوث خطأ في الاتصالء ولم ينطلق الحدث 
InfoMessage‏ إلا بعد انتهاء تنفيذ الإجراء الذي أنشأ الاتصال. 


57 فل حجم حزم البيانات :P ack ٤S1‏ 
تعيد حجم حزع البيانات (بالوحدة الثنائية واو المستخدمة في قل البيانات: 


3 تفعيل الإحصائيات :Statistics Enabled‏ 
إذا جعلت قيمة هذه الخاصية ‘True‏ فسيتم جمع إحصائيات عن عملية 
الاتصال.. لاحظ أن هذا مفيد في بعض الحالات» لكنه قد يؤدي إلى إبطاء 
الاتصدال» لهذا لا تستخدمة الا للصترووة : والقمة الاقتراضبية لهذه الخاصبية 

هي ع1'215. 


57 بون معرف الجهاز :WorkstationId‏ 
تعيد اس .جهار الل المتضل بالخائم. 


وبالإضافة إلى ما تمثله من وسائل الواجهة 11(5)001216©14101» تمتلك هذه الفئة 
الوسائل التالية: 


5 # تغيير كلمة السر :ChangePassword‏ 
أرسل إلى هذه الوسيلة نص الاتصالء وكلمة السر الجديدة التى تريد 
استخدامها مع المستخدم المحدد في نص الاتصال بدلا من كلمة السر القديمة.. 
هذا معناه أن نص الاتصال يجب أن يحتوي على اسم المستخدم (796111آ1 
وكلمة السر القديمة 53550:0» لهذا لو أرسلت نص اتصال فيه خيار 
الحماية المتكاملة 117زاءء26056/ع106 فسيحدث خطأ. 
وتقوم هذه الوسيلة بفتح اتصال خاص بها لتغيير كلمة السرء وإغلاقه فور 
الانتهاء من هذاء دون التعامل مع رصيد الاتصالات المساهمة Connection‏ 
.Pool‏ 
وتفيدك هذه الوسيلة إذا كانت كلمة السر الخاصة بالمستخدم قد انتهت 
صلاحيتها Expired‏ ويجب تغييرها.. ويمكنك معرفة هذا عند استخدام 
الوسيلة معم0 لفتح الاتصال» حيث سيحدث خطأ في البرنامج من النوع 
02 »؛ وعليك أن تفحص قيمة الخاصية :و7706 الخاصة بهذا 
الاستثناء» فان وجدت قيمتها ۱۸٤۸۷‏ أو ۱۸٤۸۸‏ فهذا معناه انتهاء صلاحية 
كلمة السر ووجوب تغييرها. 
والمثال التالي يحاول الاتصال بالخادم» فإن فشل الاتصال بسبب انتهاء 
صلاحية كلمة السو فإنه يغير كلمة اين القديمة: 
Dim Csb As New SqlConnectionString Builder‏ 
Csb.DataSource = ".\SQLEXPRESS"‏ 
Csb.InitialCatalog = "Books"‏ 
Csb.UserID = "User1"‏ 
Csb.Password = "2009"‏ 
Dim Cn As New SqlConnection(Csb. ToString)‏ 
Try‏ 
Cn.Open(O‏ 
Catch ex As SqlException‏ 
If ex.Number = 18487 OrElse ex.Number = 18488 Then‏ 
SqIConnection.ChangePassword(Csb.ToString, "2010")‏ 
End If‏ 
End Try‏ 
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ك # إلغاء المساهمة [200:ه»1): 

أرسل إلى هذه الوسيلة كائن الاتصال 4ععز1 © 501002611052 لإلغاء 
الاتصال الذي يمثله من رصيد الاتصالات المساهمة ..Connection Pool‏ 
لاحظ أن هذا الاتصال قد يكون مستخدما فى تلك اللحظة لأداء بعض 
الاستعلامات» لهذا يتم إنهاؤه في الحال» وسيظل مستخدما إلى حين إغلاقه 
باستخدام الوسيلة ©0105)؛: وعندها لن يعود إلى رصيد الاتصالات المساهمة 
بل سيغلق في الحال.. مثال: 

SqlConnection.ClearPool(Cn) 


ك 2# إلغاء كل أرصدة المساهمة 1:4112<0019ه16©: 
تغلق جميع الاتصالات الموجودة في رصيد الاتصالات المساهمة 
Connection 001‏ وإذا كان بعضها مستخدماء لا يتم إنهاؤه إلى أن يتم 
استدعاء الوسيلة ©105) الخاصة به.. مثال: 
SqlConnection.ClearAllPools( )‏ 


2# إضافة إلى قائمة التعاملات المنتشرة :EnlistDistributed Transaction‏ 
مماثلة للوسيلة .EnlistTransaction‏ 


7# الحصول على الإحصائيات :RetrieveStatistics‏ 
تعيد مجموعة تمثل واجهة القاموس '11(10101313» تحتوي على أزواج من 
المفاتيح Keys‏ والقيم 65 تمثل إحصائيات الاتصال حتى هذه اللحظة.. 
ويمكنك استدعاء هذه الوسيلة أكثر من مرة على فترات» للحصول على أحدث 
قيم للإحصائيات.. لاحظ أنك لن تحصل على أي إحصائيات إلا إذا جعلت 
للخاصية 531561051026160 القيمة ue‏ أولا. 


7# تصفير الإحصائيات :ResetStatistics‏ 
تعيد جميع قيم الإحصائيات إلى الصفر. 


كما تمتلك هذه الفئة الحدث التالي: 


1۷ 


۶ رسالة المعلومات ء6ع2و5و1010116: 
ينطلق عندما يرسل الخادم رسالة تحذير أو خطأ.. والمعامل الثاني م لهذا 
الحدث من النوع ۶ع eEven†AععSg1]nfoMessa»‏ وهو يمتلك الخصائص 
التالية: 


يو | Errors‏ تعيد مجموعة من النوع «SqlErrorCollection‏ 
التي تمثل الواجهة 100116-1100؛» وكل عنصر 
من عناصرها من نوع الفئة S٩1٤۲۲0۲‏ التي 
تحتوي على أحد الأخطاء أو التحذيرات التي 
أرسلها خادم سيكويل.. وسنتعرف على الفئة 
:01 بعد قليل. 

بي | Message‏ | تعيد نصا يشرح أول خطأ موجود في مجموعة 
الأخطاء 8015.. هذا مفيد إن كان هناك خطا 
واحد فقط, 

Source E‏ تعيد نصا يحدد اسم الكائن الذي تسبب في أول 
خطأ موجود في مجمو عة الأخطاء ۲0۲۶ ..٤‏ هذا 
مفيد إن كان هناك خطا واحد فقط. 














وقد استخدمنا فئة اتصال سيكويل في التطبيق 1ع4111011300125_11620 للاتصال 
بقاعدة بيانات الكتب على الخادم المحلي.. لاحظ أننا فتحنا الاتصال في حدث تحميل 
النموذج 1.030 ولم نغلقه إلا في حدث إغلاق النموذج ع17011010510»: مما أتاح 
لنا استخدام نفس الاتصال لتنفيذ جميع الاستعلامات التي يقوم بها المستخدم.. ورغم 
أن كائن الاتصال معرف كمتغير موضعي 773113516 1.0031 في حدث تحميل 
النموذج» إلا أننا وضعنا مرجعا له في الخاصية 1101ع126م00) الخاصة بكائن 
الأمر Command Object‏ المعرف على مستوى النموذج» مما جعل كائن 
الاتصال حيا طالما كان كائن الأمر حيا.. هذا هو السبب في أننا استخدمنا الخاصية 
Connection‏ الخاصة بعائن الأمر لإغلاق الاتصال في حدث إغلاق النموذج 
كالتالي: 
Cmd.Connection.Close( )‏ 
لاحظ أن ترك كائن الاتصال مفتوحا طوال الوقت عملي فقط فى حالتنا هذه» لأننا 
نتعامل هنا مع خادم محلي» وهناك نسخة واحدة فقط من البرنامج تتعامل معه.. لكن 
في البرامج العملية التي تتعامل مع خادم حقيقي» قد يؤدي ترك الاتصال مفتوحا إلى 
تقليل كفاءة البرنامج» خاصة إذا كان هناك عدد كبير من المستخدمين يتعاملون مع 
برنامجك في نفس اللحظة. 
افترض مثلا أنك تصمم برنامجا لشركة يعمل بها ٠٠١‏ موظفاء وأن خادم سيكويل 
مجهز لاستقبال ٠٠١‏ اتصال فقط في نفس اللحظة.. في هذه الحالة لو جعلت 


1۸ 














برنامجك يفتح نفس الاتصال بصورة دائمة طوال تشغيل المستخدم له» فإن أول 
٠‏ موظف يفتحون البرنامج على أجهزتهم سيمنعون خادم سيكويل من الاستجابة 
لمئة وخمسين موظفا آخرين إلى أن يغلق بعض المستخدمين البرنامج! 

لقد أحببت أن أريك كيف يمكن أن يؤدي التصميم الخاطئ لبرنامجك إلى نتائج 
كارثية» ويعطل العمل ولا تجني من ورائه سوى السخط © ! 

ورغم أن هذا مثال افتراضي لتقريب الفكرة» حيث إن سيكيول سيرفر يستطيع فعليا 
خدمة بضع مئات من العملاء وربما أكثر في نفس الوقتء إلا أن هذا العدد مهما بدا 
كبيرا لك فهو محدود» ويمكن تجاوزه عمليا في المؤسسات الضخمة كالحكومة 
الالكترونية مثلا (هل تتخيل كم عدد الموظفين في الوزارات المختلفة الذين 
يتعاملون مع قاعدة البيانات في نفس اللحظة؟).؛ أو في مواقع الإنترنت التي تحفظ 
قواعد بياناتها على سيكويل سيرفر» وأنت تعرف أن بعض هذه المواقع يصل 
زوارها إلى عدة ملايين يومياء مما يؤدي إلى بطء استجابة الخادم» واعتذاره للكثير 
(لا ريب أنك واجهت هذه المشكلة مع خادم بريد هوتميل في بعض الأوقات)! 
ولحل هذه المشكلة في برنامجناء عليك أن تنقل الكود من حدث تحميل النموذج 
وحدث إغلاقه إلى حدث ضغط الزرء ليتم فتح الاتصال وإغلاقه فقط عند الحاجة.. 
ولا تقلق من كثرة فتح برنامجك للاتصال وإغلاقه» فخاصية مساهمة الاتصالات 
onnection Pooling‏ التي يدعمها خادم سيكويل تغنيك عن أي عناء لحل هذه 
المشكلةء حيث يتم ترك بعض الاتصالات مفتوحة لضمان سرعة الاستجابة 
للاستعلامات المتكررة»ء دون إعاقة بعض المستخدمين عن الاتصال بالخادم.. 
ولحسن الحظ فإن تقنية المساهمة ع20011 تكون فعالة في الوضع الافتراضيء ما 
لم تطلب أنت إيقافها صراحة عبر نص الاتصال كما عرفنا سابقا. 

وستجد كود الاتصال المحسّن في المشروع المسمى 2إReade .AuthorBooks‏ 
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#4 فئة خطأ سيكيول SqIError Class‏ 


تحتوي هذه الفئة على معلومات عن رسالة الخطأ (أو التحذير) التي أرسلها خادم 
سيكويل.. وتمتلك هذه الفئة الخصائص التالية: 
57 ف الرتبة 01255: 
تعيد رقما من ٠‏ إلى ٠٠١‏ يمثل درجة خطورة الخطأ.. وقيمتها الافتراضية .٠‏ 
j 27‏ الخادم :Server‏ 
تعيد نصا يمثل اسم نسخة سيكويل سيرفر التي أرسلت الخطأ. 
37 ف المصدر ع:50111: ٠‏ 
تعيد اسم المزود 707101 الذي تسبب في الخطا. 
iF‏ الإجراء :Procedure‏ 
تعيد اسم الإجراء المخزن الذي تسبب في الخطأ. 
57 بن رقم السطر :LineNumber‏ 
تعيد رقم السطر الذي تسبب في الخطأ في الإجراء المخزن. 
57 ين الرسالة ععم11©5528: 
تعيد نصا يصف رسالة الخطأ.. .. ويمكنك أيضا استخدام الوسيلة )7:05 
الخاصة بهذا الكائن لعرض نص هذه الرسالة. 
kj 57‏ الرقم :Number‏ 
تعيد رقم الخطأ. 
57 زوز الحالة ©5)21: 
تعيد رقما من ٠‏ إلى ٠٠١‏ يمثل الكود الرقمي للخطأ. 


ملحوظة: 


من الفئة الام 10)معع1:2دره59:5 والفئة الأم Exception‏ فإنها تمتلك نفس 
خصائص الفئة «SqlError‏ مما يمنحك القدرة على الحصول على نفس المعلومات» 
سواء استخدمت الحدث InfoMessage‏ أم استخدمت الطريقة التقليدية لمعالجة 
الأخطاء .Exception Handling‏ 














۷ 
كائن الأمر‎ 
Command Object 


يتعامل كائن الأمر مع استعلام 5Q1‏ أو إجراء مخزن Stored Procedure‏ مع 
امتلاكه الوسائل اللازمة لتنفيذهما عبر اتصال مفتوح» واستلام النتيجة من الخادم. 
وسنتعرف في هذا الفصل على كيفية التعامل مع كائن الأمر. 


© واجهة أمر قاعدة البيانات IDbCommand Interface‏ 


هذه الواجهة تمثل الواجهة مااهوممء¡5]» وهي توجد في النطاق 
5.5.8 وتمتلك هذه الفئة الخصائص التالية: 


أو الاتصال :Connection‏ 
تستقبل هذه الخاصية أي كائن اتصال يمثل الواجهة 010ع11(5001226» ليتم 
استخدامه في تنفيذ الأمر.. ويشترط فتح الاتصال أولا قبل محاولة تنفيذ الأمرء 
وإلا حدث خطأ. 


و نوع الأمر :CommandType‏ 

تحدد نوع الأمر المراد تنفيذه وهي تأخذ إحدى قيم المرقم 

Command Type‏ التالية: 

الافتراضية. 

+7 الأمر يتكون من اسم إجراء مخزن يراد تنفيذه. 
1161011661 الاآمر يتكون من اسم جدول يراد تحميل كل بياناته 

كاملة من قاعدة البيانات مباشرة.. هذه القيمة غير 

مقبولة مع قواعد بيانات سيكويل سيرفرء لكن يمكن 

استخدامها مع قواعد بيانات آكسيس. 








۷۱ 

















ونا نص الأمر :Command Text‏ 

جملة SQL‏ التي تريد تنفيذهاء أو اسم الإجراء المخزن الذي تريد تنفيذه» أو 
اسم الجدول المراد تحميله» وذلك تبعا لقيمة الخاصية .CommandType‏ 
لاحظ أنك تستطيع كتابة أكثر من جملة 501 في هذه الخاصية مع الفصل 
بينها بالفاصلة المنقوطة : > وفي هذه الحالة سيتم تنفيذها جميعاء والحصول 
على أكثر من مجموعة من النتائج 1251115615» وهو نفس ما يمكن أن يحدث 
عند استدعاء إجراء مخزن يقوم بتنفيذ أكثر من جملة '5111.18:01.. وسنعرف 
كيف يمكن التعامل مع هذه النتائج لاحقا. 


وعا وقت انتظار الأمر :Command Timeout‏ 
تحدد وقت الانتظار بالثانيةء الذي سيتم بعده اعتبار محاولة تنفيذ الأمر فاشلة.. 
والقيمة الافتراضية لهذه الخاصية هي "١‏ ثانية» وعليك أن تزيدها إذا كانت 
الاستعلام معقدا يتم على جداول كثيرة ويجري عليها الكثير من العمليات» أو 
كان هناك ضغط كبير على الخادم يجعل استجابته بطيئة. 


57 فز المعاملات :Parameters‏ 
تعد أي كائن يمثل واجهة "مجموعة معاملات البيانات" 
»][(ataParameterCollection‏ التي ترث واجهة القائمة 11.156.. وتتيح 
لك مجموعة المعاملات إضافة المعاملات المطلوب التعويض بها في جملة 
الاستعلام أو الإجراء المخزن.. وسنتعرف على المعاملات بالتفصيل لاحقا. 


ونج التعامل :Transaction‏ 
تستقبل أي كائن من نوع واجهة تعاملات قاعدة البيانات «IDbTransaction‏ 
ليتم تنفيذ الأمر الحالي في نطاقه. 


وخ مصدر الصفوف المحدثة :UpdatedRowSource‏ 
تحدد كيف سيتم تحديث صفف البيانات 173131201 الموجود في أحد جداول 
مجموعة البيانات +22362596.. لاحظ أن هذه الخاصية مفيدة فقط عندما يكون 
كائن الأمر الحالي هو أمر التحديث 7220تده© 11001346 الخاص بموصل 
البيانات DbDataAdapter‏ الذي يملأ مجموعة البيانات ويحدثها. . ويتم تنفيذ 
أن التحديث على الضتفوفه التى ترت فى سمورهية البانات :و اهدا تلن 
الآ خر وفك بحتسيو فاا الاسر علي معسافلات اخسيراج 
»0utput Parameters‏ أو ترافقه جملة 9٤8٣1‏ تعيد السجل بعد تحديثه 
في قاعدة البيانات.. الحكمة في هذا أن هناك بعض القيم التي تولدها قاعدة 
البيانات بنفسها (مثل عمود الترقيم التلقائي) ولا يمكنك معرفة قيمة هذه 
الأعمدة إلا بالحصول على السجل مرة أخرى بعد تحديثه (أو إضافته).. 


۷۲ 





وتتحكم هذه الخاصية في كيفية الاستفادة من القيم العائدة من أمر التحديث» 
وهي تأخذ إحدى قيم المرقم عع:2ج012161901:501م7] التالية: 

None‏ يتم تجاهل أي معاملات أو صفوف عائدة من 
أمر التحديث. 
25 اتوضع قيم معمملات الإخراج 
0utput Parameters‏ في خانات سجل 
مجموعة البيانات +©1021256. 
1016010 | توضع قيم أول سجل عائد من أمر التحديثء 
في سجل مجموعة البيانات. 
Both‏ توضع قيم معاملات الإخراج وأول سجل عائد 
من أمر التحديث» في سجل مجموعة البيانات. 








كما تمتلك هذه الواجهة الؤسائل الثالية: 


: Prepare تجهيز‎ 5 


تنشئ نسخة محسنة مجهزة من الأمر وت تحفظها على الخادمء ليكون تنفيذها 
أسرع.. ولا تستقبل هذه الوسيلة معاملات» وليس لها قيمة عائدة» ولا يكون لها 
أي تأثير إن كانت للخاصية Command Type‏ القيمة +ععز([18616. 

لاحظ أن استدعاء هذه الوسيلة صار عديم القيمة تقريباء لأن إصدارات 
سيكويل سيرفر ۲۰۰۰ و 5٠05‏ و ۲۰۰۸ تقوم بتجهيز البيانات تلقائيا عند 
اللزوم» لتحسين الأداء. 


إنشاء :CreateParameter Jalan‏ 
تعيد كائنا من النوع إ عع Para n»‏ taهD([»‏ لتخصصه للتعامل مع أحد 
المعاملات: الوه في ال 


ف تنفيذ بدون استعلام :ExecuteNonQuery‏ 


تنفد الأمر دون أن تعيد أية سجلات» ولكن تعيد عددا صحيحا Integer‏ يمثل 
عدد السجلات التي تأثرت بتنفيذ الأمر. . ويمكنك استخدام هذه الوسيلة لتنفيذ 
أوامر التحديث Update‏ والحذف ع)ع[ع0 والإدراج 116ءع05]. 
وستجد مثالا على هذه الوسيلة في الزر R٤۸1 ۴٤ ۴۸0٣‏ في المشروع 
Procedure‏ الذي عرفنا من قبل أنه ينشئ إجراء مخزنا في 
قاعدة بيانات الكتب المنشأة : بتطبيق ووءعع40. في هذا الزر نستخدم كائن أمر 
من النوع 3320تد0161(600) للتعامل مع قاعدة بيانات ووعن0,رء: ونستخدم 
الوسيلة 106116101001615 لتنفيذ استعلام 5001 الذي ينشئ الإجراء 
المخزن في قاعدة البيانات» لأنه لا يعيد إلينا أي ناتج. 


لاا 

















لاحظ أن كود الاتصال بقاعدة البيانات وتنفيذ الأوامر يتكرر كثيراء وهو يبدو 

طويلا مع وجود تعديلات طفيفة.. لهذا سيكون من الأذكى لو جمعنا الكود 

المتشابه في إجراء وأرسلنا إليه المعاملات التي تناسب الاستعلام الذي ننفذه.. 

ولقد فعلنا هذا في المشروع )وه 1ط( حيث عرفنا فيه فئة اسمها 

:01 وأضفنا إليها خاصية اسمها :00226011005 تستقبل 

نص الاتصالء وحدث إنشاء 0025600101 يستقبل نص الاتصال أيضا 

ركه فق هذه الخاضصية على سيل الاختصنار ...وقد عر فنا فن هذه الفئة ندا 

من الوسائل التي تتيح لنا التعامل مع قاعدة البيانات» ومن بينها دالة اسمها 

..ExcuteCommand‏ هذه الدالة تستقبل معاملين: 

- نص الأمر 6 1723201دزه") الذي تريد تنفيذه.. ويمكنك أن ترسل 
إلى هذا المعامل استعلام ,501 أو اسم إجراء مخزن» حيث سنقوم 
باستنتاج نوع الأمر بحيلة صغيرة» فلو كان النص يبدأ بأي من أوامر 
501 مثل " ۲٤۲موم"‏ أو " مtوdمں"...‏ إلخ» فمعنى هذا أنه نوع الأمر 
.0011112201506 .. لاحظ أننا وضعنا مسافة بعد اسم الكلمة» 
تلافيا لاحتمال أن تكون هذه الكلمة جزءا من اسم إجراء مخزن 
(مثل 1]015ا1كرء10134])»: فنحن واثقون أن اسم الإجراء المخزن لا 
يحتوي على مسافات» بينما الاستعلامات تحتوي على مسافات.. غير 
هذا يكون نوع الأمر .CommandType.StroresProcedure‏ 
- مصفوفة نصية تنائية البعد (,)ع591»: يتكون كل عنصر فيها من اسم 

التعامل وففكة, وها تك تمر ين المعاملات نافدر إلى الا 
حيث سنضيف هذه المعاملات إلى مجموعة معاملات الأمر 
5 ووإذا لم يكن للأمر معاملات» فأرسل 
إلى المعامل الثاني للدالة عصمتطاه1!. 

وتستخدم هذه الدالة الوسيلة Command .ExecuteNon Query‏ لتنفيذ 

الأمرء وتعيد 6نم1 إذا لم يحدث خطأء وتعيد »115 إذا حدث خطأ. 

وستجد مثالا على استخدام هذه الدالة في نفس المشروعء حيث وضعنا مربعي 

نص على النموذج لاستقبال اسم المؤلف ونبذة عنه» وعند ضغط الزر يتم 

تنفيذ استعلام لإضافته إلى جدول الكتب.. انظر كيف سيكون الكود في منتهى 

البساطة والاختصار باستخدام الفئة :MyDbConnector‏ 


Ni 





Dim DbBooks As New MyDbConnector( 


My.Settings.BooksConStr) 


Dim SQL = "INSERT INTO Authors " & 


" (Author, CountryID, About)" & 
" VALUES (@Author, 21, (@About)" 
Dim Params = {{"@Author'"", TxtAuthor.Text.Trim}, 
{"@About'"", TxtAbout. Text. Trim}} 
11 DbBooks.ExcuteCommand(SQL, Params) Then 


TxtAuthor.Clear() 
TxtAbout.Clear() 
End If 


ويمكنك استخدام الفئة 143:1(5000126©101 للتعامل مع أي قاعدة بيانات» 
وتنفيذ أي أمر عليها باستخدام الإجراء 1001160010171210.. أليس هذا شیئا 


مريحا؟ 


:Execute Reader تنفيذ قارئ‎ 

تنفذ الأمرء وتعيد كائنا من النوع 11(3421262061» حيث يمكنك استخدامه 
لقراءة النتيجة سجلا تلو سجل.. وسنتعرف على قارئ البيانات لاحقا. 

وستجد مثالا على هذه الوسيلة في المشروع .AuthorBooks_ Reader‏ 
ولهذه الوسيلة صيغة ثانية؛ تستقبل معاملا من نوع المرقم 
107101 الذي يحدد سلوك قارئ البيانات» كالتالي: 


Default 


SingleResult 


SchemaOnly 





السلوك العادي» حيث يمكن أن يؤدي تنفيذ الأمر إلى 
الحصول على أكثر من مجموعة من مجموعات النتائج 
ئ 11و12 (كما يحدث في حالة تنفيذ أكثر من جملة 
SQL‏ من داخل إجراء مخزن).. هذا مكافئ لاستدعاء 
الوسيلة Execute R e261‏ بدون معاملات. 

يؤدي تتفيذ الاستعلام إلى الحصمول على محر غا ا 
واحدة فقط, 

يحدى نلية الأسفلاء إلى الحصبول على ارات 
الأعمدة فقط بدون أي سجلات.. هذا يعني الحصول على 
جدول فارغ به أسماء الأعمدة فقط.. هذا مماثل لاستخدام 
مزود سيكويل للخيار: 





SET FMTONLY ON 

















13/1010 | يؤدي تنفيذ الاستعلام إلى الحصول على معلومات الأعمدة 

.Primary Key والمفتاح الأساسي‎ 

161037 | يؤدي تنفيذ الاستعلام إلى الحصول على سجل واحد مقط 

التتائج» فسيكون بكل مجموعة منها سجلا واحدا فقط.. 

استخدم هذا الاختيار عندما تحتاج إلى أو سجل فقطء فهذا 

يؤدي إلى تحسين أداء وسرعة البرنامج. 

Sequenti1‏ | قراءة تتابعية.. هذا مفيد للقراءة من الأعمدة التي تحوي 
و9 أقدرا ضخما من البيانات» فبدلا من طلبها كلها من الخادم» 

يتم طلب أجزاء من البيانات فقط تبعا لاحتياجك.. لاحظ الآتي: 

- يجب عليك قراءة قيم الحقول بنفس ترتيبها في الاستعلام؛ 
لأنك لو قرأت أي حقل» فلن تستطيع قراءة الحقل السابق 

مرة أخرىء فنحن هنا نقرأً البيانات تتابعياء أي 


- استخدم الوسيلة عںآه ۷ء6 لقراءة القيمة الموجودة في 
أي حقل كاملة. 


- استخدام الوسيلة وع:66183 الخاصة بقارئ البيانات 
لقراءة أجزاء من الحقل الذي يحتوي على بيانات ثنائية 
ضخمة؛ مثل image‏ و .varbinary(MAX)‏ 
- استخدام الوسيلة 061015 الخاصة بقارئ البيانات 
لقراءة أجزاء من الحقل الذي يحتوي على نصوص 
بض خمة. مثل text‏ و ntext‏ و varchar(MAX)‏ 
و .nvarchar(MAXK)‏ 
والمشروع 263011318610868 يقرأ الصور الخاصة 
بشعار كل ناشر من الجدول ١إعطءناطاں۴؛‏ ويحفظها في 
ملف على الجهاز.. ونظرا لأن الصورة قد تكون ضخمة؛ 
فة 'امتتخدمتا هذا الخيار لنفرأ البيافات قايا ويزيك هذا 
المشروع أن هذه الطريقة تصلح للقراءة من الحقل 080.آ 
الذي نوعه «image‏ وتصلح أيضا للقراءة من الحقل 
2 الذي نوعه .varbinary(M AX)‏ 
مئاع /يتم إغلاق الاتصال 105ع6م00) مع قاعدة البيانات ألياء 
0 | | بمجرد إغلاق قارئ البيانات. 
ويمكنك استخدام أكثر من قيمة من هذه القيم» بربطها معا باستخدام المعامل ا0. 
وقد أضفنا وسيلة اسمها GetReader‏ إلى الفئة MyDbConnector‏ في 
المشروع )وهآ ا5؛ مهمتها تنفيذ استعلام باس تخدام الوسيلة 


۷٦ 
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ExecuteReader‏ وإعادة قارئ البيانات.. لاحظ أنك لو أغلقت الاتصال في 
نهاية هذه الوسيلة فسيحدث خطأ عند محاولتك استخدام قارئ البيانات الذي 
أعادته إليك» لأن الاتصال الذي يستخدمه قد ثم إغلاقه. . لهذا عليك عدم اغلاق 
الاتصاJ«‏ وإرسال القيمة CommandBehavior.CloseConnection‏ إلى 
معامل الوسيلة 61ع1611620ح1:6 لجعل قارئ البيانات يغلق الاتصال بنفسه 
عندما يتم إغلاقه.. وقد جعلنا للوسيلة 1ع262620) معاملا اختياريا اسمه 
Sequential‏ إذا جعلته عن[' فستحصل على قارئ بيانات تتابعي لاستخدامه 
في قراءة البيانات الضخمة على أجزاءء والقيمة الافتراضية لهذا المعامل هي 
156 لتحصل على قارئ بيانات عادي. 

وستجد مثالا لاستخدام هذه الوسيلة في نفس المشروع في زر "الكتب".. هذا 
الزر يعرض كتب المؤلف الذي كتبت اسمه في مربع النص العلوي. 


تنفيذ قيمة :ExecuteScalar‏ 

تنفذ الأمرء وتعيد كائنا ٥٥٤‏ زط0 يحتوي على قيمة الخانة الموجودة في الصف 
الأول من العمود :الأول في الحدو ل الداتب::وتتجاهل باق الكانات 

ويمكنك استخدام هذه الوسيلة لتنفيذ دوال التجميع .Aggregate Functions‏ 
والمشروع 11 يريك مثالا على استخدام هذه الوسيلة لمعرفة متوسط 
أسعار الكتب. 

وقد أضفنا وسيلة اسمها GetValue‏ إلى الفئة MyDbConnector‏ في 
المشروع )وهآ ا5؛ مهمتها تنفيذ استعلام باس تخدام الوسيلة 
1233 وإعادة القيمة الناتجة» وستجد مثالا لاستخدامها في نفس 
المشروع في الزر "معرفة عدد المؤلفين". 


إلغاء :Cancel‏ 
تحاول إلغاء تنفيذ الأمر.. ولا يحدث خطأ إن لم يكن الأمر قيد التنفيذ حالياء أو 
إن فشلت في إيقاف تنفيذه. 


¥ 


24 فئة أمر قاعدة البيانات DbCommand Class‏ 


هذه الفئة أساسية مجردة «Abstract Base Class‏ تجب وراثتها «MustInherit‏ 
وهي ترث فة المكون 6013255 001100261826©: كما أنها تمثل الواجهة 
148 و«وبالتالي تمتلك جميع وسائلها وخصائصها. 

وبالإضافة إلى ما تمثله من خصائص الواجهة 11(0001711210» تمتلك هذه الفئة 
الخاصية التالية: 


وخ مرئية في وقت التصميم :Design TimeVisib]e‏ 
إذا جعلت قيمة هذه الخاصية 1536 (وهي القيمة الافتراضية)» فسيظهر كائن 
الأمر في وقت التصميم في واجهة الأدوات التي تستخدمه. 


ولا تمتلك هذه الفئة أي وسائل جديدة غير ما تمثله من وسائل الواجهة 
122212110 . 
لاحظ أن الفئات التالية ترث الفئة 1(01:111121101: 
.OdbcCommand Class .١‏ 
؟. .OleDbCommand Class‏ 
.SqlCommand Class .‏ 
.OracleCommand Class .“‏ 
وسنكتفي هنا بالتعرف على الفئة 501001172740. 


SqICom mand Class فئة أمر سيكويل‎ 2 


هذه الفئة ترث الفئة 120017120 وهي مخصصة للتعامل مع الأوامر التي يتم 
تنفيذها على خادم سيكويل سيرفر. 
ولحدث إنشاء هذه الفئة أربع صيغ مختلفة: 
.١‏ الصيغة الأولى بدون معاملات. 
1 والصيخة الثائية لها معائل واهدء قل تهى امان الذى سرك :فى 
الخاصية .Command1ext‏ 
". والصيغة الثالثشة تزيد على الصيغة السابقة بمعامل تان من النوع 
)1 » يستقبل كائن الاتصال الذي سيتم تنفيذ الأمرمن خلاله. 
.٤‏ والصيغة الأخيرة تزيد على الصيغة السابقة بمعامل ثالث من النوع 
00 هه يستقبل كائن التعامل الذي سيتم تنفيذ الأمر في نطاقه. 
وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخاصيتين التاليتين: 


۷۸ 


أ التنبيه :Notification‏ 
تحدد كائن طلب التنبيه 011©51 501210112110516 الذي سيستخدمه كائن 
الأمر في تلقي التنبيهات من الخادم عند تنفيذ الاستعلام.. وسنتعرف على الفئة 
SglNotificationRequest‏ لاحقا. 


يونعم ضم تلقائي إلى قائمة التنبيهات :NotificationA uto Enlist‏ 
إذا جعلت قيمة هذه الخاصية 1:16؛ فسيستقبل كائن الأمر تنبيهات تلقائية من 
كائن معلومات التبعية 387©ع50110661060.. وتستخدم هذه الخاصية مع 
صفحات المواقع في '4572.711:1 لتتيح عرض الصفحة المجهزة إلعطيCa‏ 
6 إلى أن يأتي تنبيه بحدوث تغير في بعض بياناتها فيتم إنعاشها.. 
وسنتعرف على الفئة 501106061061637 لاحقا. 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الوسائل التالية: 


7# نسخ :Clone‏ 
تعيد كائن 501000117112110 جديدا مماثلا في كل شيء للكائن الحالي. 


#< تصفير زمن انتظار الأمر :ResetCommand Timeout‏ 
تعيد قيمة الخاصية 01717131101111060116) إلى قيمتها الافتراضية "١‏ ثانية. 


7# "تنفيذ قارئ بيانات :ExecuteXmIReader "XML‏ 
تنفذ الأمرء وتعيد كائنا من النوع 3532111:62061»: الذي يحتوي على البيانات 
بتنسيق 72711.. لاحظ أن عليك استخدام هذه الوسيلة في الحالات التالية: 
- عند استخدام الفقرة 73/41 +7001 في جملة الاستعلام.. هذه الفقرة تعيد 
ناتج الاستعلام في صورة وثيقة 1]/ل2. 
- عند قراءة عمود نوع بياناته .×M1‏ 
- عند قراءة عمود نوع بياناته 464 أو 7731181 لكنه يحتوي على 
بيانات بتنسيق .×M1‏ 
ولن نتطرق إلى فئات ,52/1 في هذا الكتاب» وسنفرد لها كتابا مستقلا إن قدر 


الله. 
وتدعم الففنة SqlCommand‏ استخدام العمليات غير المتزامنة 
synchronous Operations‏ لتنفيذ الأمرء وذلك من خلال أزواج الوسائل 
التالية: 


۷۹ 


EndExecuteXmlIReader 9 BeginExecuteXmlIReader 0‏ 
EndExecuteNonQuery 9 BeginExecuteNonQuery 9‏ 
EndExecuteReader # BeginExecuteReader 9‏ 
حيث تقوم الوسائل التي تبدأ بالكلمة مزع»8 بتنفيذ الأمر في عملية غير متزامنة 
ويمكنك أن ترسل إليها مندوبا عن إجراء يتم استدعاؤه بعد انتهاء العملية لتقرأ فيه 
البيانات الناتجة.. وتعيد هذه الوسائل كائنا يمثل الواجهة 1537001651016 ليمكنك 
استخدامه في متابعة العملية» كما يمكن إرساله إلى الوسائل التي تبدأ بالكلمة 0م17 
لإنهاء العملية غير المتزامنة والحصول على نتائجها. ۰ 
وتمتاز العمليات غير المتزامنة بأنها لا توقف تنفيذ البرنامج إلى حين انتهاء إتمام 
العملية» بل ينتقل التنفيذ إلى السطر التالي مباشرة: بينما ترسل النتائج فور توفرها 
إلى الدالة الخاصة بالحصول على النتائج 1001102 عاء021163.. وتقع العمليات 
غير المتزامنة خارج نطاق هذا الكتاب» وسنتعرف عليها بالتفصيل بإذن الله في 
كتاب المواضيع المتقدمة في برمجة إطار العمل. 


كما تمتلك الفئة 5010017210 الحدث التالي: 


:StatementCompleted اكتملت الجملة‎ F 
ينطلق عند اكتمال تنفيذ جملة الاستعلام الخاصة بكائن الأمر.. والمعامل الثاني‎ 
وهو يمتلك‎ ›StatementCompاete4‎ ٤v eA gs م لهذا الحدث من النوع‎ 
التي تعيد عدد‎ ‘RecordCount خاصية واحدة هي "عد السجلات"‎ 
السجلات التي تأثرت بتنفيذ جملة الاستعلام.‎ 


تمرير القيم إلى جمل الاستعلام: 


افترض أنك تريد الحصول على كتب "توفيق الحكيم" من قاعدة البيانات.. في هذه 
الحالة يمكنك وضع جملة ,501 التالية في الخاصية 001112101206 لكائن 


الأمر (وليكن اسمه 20©): 


Cmd.CommandText = "SELECT Books.Book '" + 
"FROM Authors, Books " + 
"WHERE Authors.ID = AuthorID '" + 
"AND Authors.Author = "'توفيق الحكيم'‎ 


ولكن» هل تظن أنك ستكتب الجملة السابقة في أي تطبيق عملي فعلا؟.. هل 
ستقتصر وظيفة برنامجك على عرض كتب مؤلف واحد فقط أم أنك ستسمح 
للمستخدم باختيار المؤلف الذي يرده ليعرض له البرنامج كتب هذا المؤلف؟ 
المنطقي والعملي» هو أن تضع على النموذج مربع نص (وليكن اسمه 
01[ ) ليكتب فيه المستخدم اسم المؤلف» ومن ثم تعرض له كتبه.. في مثل 
هذه الحالة» عليك تعديل نص الاستعلام السابق ليصير كالتالي: 


Cmd.CommandText = "SELECT Books.Book '"" + 
"FROM Authors, Books " + 
"WHERE Authors.ID = AuthorID '" + 
"AND Authors.Author = '" + TxtAuthor.Text +'"'" 


حيث استخدمنا طريقة تشبيك النصوص في الكود» لإضافة النص الموجود في 
مربع النص إلى جملة الاستعلام» وبهذا حصلنا على جملة استعلام مرنة» تستطيع 
البحث عن اسم أي مؤلف يريده المستخدم. 

لكن هذه الطريقة تحتوي على ثغرة قاتلة» تسمح للأشقياء بتدمير قاعدة بياناتك 
وربما نظام التشغيل الذي يوجد عليه خادم سيكويل لو أرادوا! 

كيف؟.. هذا هو موضوع الفقرة التالية. 
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دس الاستعلامات Injection‏ 5001: 

في المثال السابق» سمحنا للمستخدم بكتابة اسم المؤلف في مربع نصء ثم أدرجنا 
محتوى النص داخل جملة الاستعلام كجزء من شرط الفقرة HER۴‏ .. وقد تفتق 
ذهن بعض العباقرة عن فكرة شريرة» وهي كتابة بعض جمل الاستعلام في مربع 
داخل جملة الاستعلام الخاصة بك» فيقوم برنامجك بتنفيذ ما يريدون على قاعدة 
البيانات» وهو أمر يشبه سلوك الفيروسات التي تحقن مادتها الوراثية في نواة الخلية 
وتتركها تنفذها لإنتاج فيروسات جديدة! 

وخطورة هذه الطريقة هي أنها تتيح للمخترقين الاستعلام عن بعض حسابات 
المديرين والمستخدمين» ومعرفة تركيب الجداول» بل وتنفيذ بعض أوامر غلاف 
الويندوز 51611 من خلال خادم سكيويل» مما قد يضر بالجهاز الذي يعمل عليه 
الخادم! 

ولكن كيف تتم عملية الحقن 661100 م]؟ 

-١‏ أول شيءء يتوقع القرصان +/ع1ع113 ضرورة وجود النص بين علامتي 
تنصيصء ولا بد أنك وضعت علامة تنصيص بادئة قبل النص الذي سيأتي 
من مربع النصء لهذا يجب على المخترق أن يكتب أي كلمة»ء ثم يتبعها 
بالعلامة ' لإغلاق علامتي التنصيصء وبهذا يضمن عدم حدوث خطأ في 

تقد بهذا + كاده فصان ا ; ليستطيع كتابة أمر ,5001 جديد 
کاش ت ا لديه الحرية في كتابة الأمر الذي يريده! 

۳- نظرا لأن القرصان يتوقع منك إضافة تكملة لجملة 8Q1‏ بعد النص الذي 
كتبه في مربع النص» فإنه يضع في نهاية الكود المدسوس الرمز -- ليجعل 
أي نص تال له مجرد تعليق» وبهذا يلغي أي تكملة خاصة بك لجملة 

والآن» دعنا نرى ماذا سيحدث لو كتب القرصان في مربع النص الجملة التالية: 
Ahamd'; drop table Books--‏ 
في هذه الحالة ستصبح جملة الاستعلام بعد إضافة هذه الجملة كالتالي: 
SELECT Books.Book‏ 
FROM Authors, Books‏ 
WHERE Authors.ID = AuthorID‏ 
AND Authors.Author = 'Ahamd'; drop table Books--'‏ 
كما ترى: صار لدينا استعلامان صحيحان وتعليق: 

9 الاستعلام الأول لا قيمة له» وهو يبحث عن كتب مؤلف اسمه )2ط طA.‏ 

- والاستعلام الثاني أمر حذف يطلب حذف جدول الكتب كاملا من قاعدة 
البيانات.. لاحظ أن القرصان لا يعرف أسماء الجداول»ء ولكنٌ توقع اسم 


۸۲ 


جدول الكتب لن يكون عسيراء ولن ييأس القرصان من تجربة عشرات 
الأسماء المحتملة» ما دام عزمه قد قر على تدمير برنامجك! 

وقي اا بر تلق شمر هو العلامة لكا سةك و التي اطا 
القرصان تهميشها بحيلة صغيرة بار عة! 


يبدو الأمر مفزعاء أليس كذلك؟ 
إن هذه الثغرة تتيح للقراصنة تدمير قاعدة البيانات» ودخول حسابات المستخدمين» 
دون الحاجة إلى كتابة اسم المستخدم أو كلمة المرورء والكثير من الكوارث التي 
تكفي لتطير النوم من عيون المبرمجين ©. 
فكيف إذن يمكن إغلاق هذه الثغرة القاتلة؟ 
في الحقيقة هناك عدة نصائح هامة في هذا الصدد: 

-١‏ التقليل من استخدام مربعات النصء والاستعاضة عنها بأدوات تتيح اختيار 


القيم» »> مثل القوائم 5 إن كان هذا ممكنا. 


۲- استخدام الخاصية MaxLength‏ الخاصة بمربع النص لتحديد طول النص 
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المسموح بكتابته في مربع النص.. هذا سيحد من قدرة القرصان على كتابة 


إجراء بعض الفحوصات الصغيرة على قيمة مربع النصء للتأكد من خلو 
النص الذي كتبه المستخدم من العلامات المريبة مثل :' -- */ /* .. 


هذا سيشل حركة القرصان تماما.. والأفضل أن تمنع كتابة هذه الحروف 
في مربع النص من المنبع باستخدام الحدث ووعإy۲مK.‏ 


- عليك أيضا أن تمنع الكلمات الدالة على أوامر .501 في مربع النص» 


6 


خاصة DROP‏ و DELETE‏ و UPDATE‏ و .INSERT‏ 
لا تقبل أيا من الكلمات التالية في مربع نص يدخل فيه المستخدم اسم ملف: 
AUX, 01001, CON, 001111009, NUL, PRN‏ 


00111, COM2, COM3, COM4, COM5, COM6, COM7, COMS 


LPT1, LPT2, LPT3, LPT4, LPT5, LPT6, LPT7, LPTS 
من المهم أيضا أن تحدد صلاحيات مستخدمي قاعدة البيانات» وألا تعطي‎ 
الصلاحيات الخطيرة (كحذف الجداول أو إنشائها) إلا للمديرين» وعليك أن‎ 
تصنع نسخة خاصة من البرنامج لهؤلاء المديرين بحيث لا يتم تداولها إلا‎ 
بينهم.. أما المستخدمون العاديون» فعليك أن تصنع لهم نسخة أخرى من‎ 
البرنامج» وأن تتصل هذه النسخة بالخادم من خلال حساب مستخدم محدود‎ 
الصلاحيات» وبهذا لو نجح أي قرصان في تجاوز خطوط دفاعك عبر هذه‎ 
النسخة؛ لا يجد الكثير مما يستطيع فعله!‎ 
كن حذرا من الكلمات التي تبدأ ب _مكء لأنها البادئة التي يتم بها تسمية‎ 
الوا ال د اة انكف قا عا ااك‎ 
.xp_cmdshe]1 مثل الإجراء‎ «Catalog-extended stored procedures 


A 


۸- استخدام الإجراءات المخزنة esإduمعPro"‏ 5100 في تنفيذ 
الاستعلامات» لأنها تكون محفوظة في قاعدة البيانات على الخادم» ومن ثم 
يقوم سيكويل سيرفر بفحص قيم المعاملات المرسلة إلى الإجراء المخزنء 
والتاكد من.أنها من التو ع الضتحيم وبالطول المخد 

5 ۹- ارفض كتابة الكلمات التالية في مربع النص» لأنها تسمح بحقن الأكواد 
المدسوسة في الإجراءات المخزنة: 
EXECUTE, EXEC, sp_executesql‏ 
-٠‏ استخدام المعاملات 231311615 لتمرير القيم إلى جمل الاستعلام» بدلا 
من استخدام طريقة تشبيك النصوص 2007202314613101»: لأن المعاملات 
تضمن التحقق من نوع المعامل والطول المسموح به لقيمته.. لكن 
نصيحة: لا تتخل عن فحص النصوص التي يكتبها المستخدم في مربعات 
النصية الطويلة بعبور بعض الكود المدسوس. 
وفي المشروع AuthorBooks_ Reader‏ استخدمنا الإجراء SqIInjection‏ 
للتأكد من أن النص الذي كتبه المستخدم في مربع النص لا يحتوي على أية رموز 
أو كلمات مرا وكا اها معاملا ازور الخض إلى الاستفااء لمزية من 
الحماية. 
كما استخدمنا الدالة 10]ن 6م5011 في المشروع 17012515 للتأكد من أن قيم 
المعاملات لا تحتوئ على استعلامات مدسنوسة. 
وسنتعرف فيما يلي على المعاملات وكيفية استخدامها. 
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المعاملات :Parameters‏ 
المعامل هو علامة موضعية 21306101061 توضع في جملة ,501 لتشير إلى أن 
هناك قيمة سيتم التعويض بها بدلا منها.. ويمكنك تعريف أي عدد تريده من 

المعامللات في جملة الاستعلام. 
وتختلف صيغة هذه العلامة تبعا لنوع مزود البيانات» فمزود سيكويل يستخدم الرمز 
© لتمييز المعاملء يتبعه اسم متغير بدون أن يفصل بينهما مسافات 

(مثل عج:ة175611©)).. لهذا نستطيع كتابة الاستعلام عن كتب أحد المؤلفين كالتالي: 
Cmd.CommandText = "SELECT Books.Book '" +‏ 
"FROM Authors, Books '" +‏ 
"WHERE Authors.ID = AuthorID " +‏ 
"AND Authors.Author = @Author" ٍ‏ 
هذا يبدو كأننا عرفنا متغيرا اسمه ۲طا۸ @ واستخدمناه في جملة الاستعلام» ليتم 
التعويض عنه عند تنفيذها. 
أما في مزود 01٤58‏ و 0108 فيتم استخدام علامة الاستفهام الإنجليزية 9 
للإشارة إلى وجود معامل» دون منح هذا المعامل أي اسم: 
Cmd.CommandText = "SELECT Books.Book '" +‏ 
"FROM Authors, Books '" +‏ 
"WHERE Authors.ID = AuthorID " +‏ 
"AND Authors.Author = ?"‏ 
لاحظ أن قواعد بيانات آكسيس صارت تقبل تسمية المعاملات (وما زالت تقبل 
العلامة ? أيضا)ء لكنها لا تميز المعاملات المسماة باستخدام أي علامة خاصة.. 
يمكنك مثلا أن تكتب الاستعلام السابق كما يلي: 
Cmd.CommandText = e Books.Book " +‏ 
"FROM Authors, Books "‏ 
"WHERE Authors.ID = E "+‏ 
"AND Authors.Author = AuthorValue"‏ 
في هذه الحالة ستعتبر آكسيس أن 411401572116 هو اسم معامل.. بل يمكنك أيضا أن 
تستخدم الاسم 41141201 @ في الاستعلام» وستقبله آكسيس كاسم معامل» وهذا يساعدك 
على استخدام نفس استعلامات سيكويل سيرفر مع آكسيس! 
لكن هذا المرونة من آكسيس تسبب مشكلة غريبة في بعض الأحيان» فلو أخطأت 
مثلا في كتابة اسم الحقل (1110111ر في الاستعلام السابق» وكتبته مثلا Authe]15ء‏ 
فستعتبره آكسيس اسم معامل» وبدلا من أن تحصل في برنامجك على رسالة تخبرك أن 
هذا العمود ليس موجودا في الجدول» ستحصل على رسالة تخبرك بأن قيم بعض 
المعاملات مفقودة.. هذا هو السبب الذي سيجعلك ترى آلاف الأسئلة من المبرمجين عن 
سبب ظهور هذه الرسالة الغربية في برنامجهم: 
No value given for one or more required parameters"‏ 


رغم أنهم لا يستخدمون استعلامات فيها معاملات» أو أنهم مرروا قيم المعاملات 
الصحيحة فعلا!.. فكل ما هناك» أنهم أخطأوا في كتابة اسم أحد الحقول» فتم اعتباره 
معاهلاة! 
ولكن» كيف يمكن التعويض عن قيم المعاملات؟ 
لفعل هذاء عليك استخدام مجموعة المعاملات الخاصة بكائن الأمر 
5 لتعريف كائنات المعاملات ووضع القيم فيهاء 
حيث سيقوم كائن الأمر بتمريرها إلى جملة الاستعلام عند تنفيذ الأمر. . وعليك أن 
ا الى ان و زمر المدامل فى مله مجك لا رت E‏ 
نال ات شن عرف معاملء ن مجموعة المعاملات هة نوع 
القيمة التي يقبلها المعامل» وتمرير القيمة من خلاله إلى كائن الأمر. 
ويشترط في حالة سيكويل سيرفر أن يكون لكل من المعامل الموجود في نص 
الاستعلام والمعامل الموجود في مجموعة المعاملات نفس الاسم.. فإذا عرفت في 
نص الاستعلام معاملا اسمه 4:1]01©)» فيجب أن يكون اسمه في مجموعة 
المعاملات يض .@Author‏ 
أما معاملات 01٤58‏ و 01080 فكلها ممثلة بالرمز 9 مما يجعلك مضطرا إلى 
تعريفها في مجموعة المعاملات عع Db Command.Para‏ بنفس ترتيب 
ظهورها في نص الاستعلام. . وحتى لو كنت تستخدم معاملات مسماة في أكسيس» 
فما زلت مضطرا إلى المحافظة على الترتيب الصحيح لهذه المعاملات» كما أن اسم 
كل معامل ما زال غير مهم» لهذا تستطيع تعريف معامل في مجموعة المعاملات 
اسمه × ليعوض عن معامل في نص الاستعلام اسمه 1101م @.. فكل ما يهم 
حقا هو الترتيب وليس الاسم.. يمكنك اعتبار أن آكسيس يمحو اسم المعامل ويضع 
بدلا منه علامة استفهام 9 على سبيل التسهيل عليك. 
هذا هو ما جعل من الممكن أن نستخدم نفس جملة الاستعلام» ونفس كود تعريف 
المعاملات في حدث ضغط زر "الكتب" في المشروع 730101165 للحصول على 
كتب أحد المؤلفين من قاعدة الكتب في آكسيس أو قاعدة الكتب في سيكويل سيرفر. 
الان دعا ر ف عن سحموعة المعاملاك» و لفات المتتكدمة مها 
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tg‏ فئة مجموعة معاملات قاعدة البيانات 
DbParameterCollection Class‏ 


هذه المجمو عة تمثل الواجهة 1103432313126161001160110» التي ترث واجهة 
القائمة ئ1 [1[.. وكل عنصر يضاف إلى المجموعة DbParameterCollection‏ 
هو من نوع الفئة اع]ع 1267221 التي سنتعرف عليها لاحقا. 
ولا تحتوي هذه الفئة على أية خصائص أو وسائل جديدة غير ما تمثله من عناصر 
ا 
لاحظ أن الفئة 60ع1(52218226]61000116 أساسية مجردة تجب وراثتهاء لهذا 
ترثها كل من الفئات التالية: 
OdbcParameterCollection Class .١‏ 
OleDbParameterCollection Class .Y‏ 
؟. SqlParameterCollection Class‏ 
؟. OracleParameterCollection Class‏ 
.SqlParameterCollection Class‏ 


2 فئة مجموعة معاملات سيكويل 
SqIParameterCollection Class‏ 


هذه الفئة ترث الفئة 10۸اc‏ ]1 »b Parameter‏ وهي لا تختلف عنها كثيرا إلا 
في أن عناصرها من نوع الفئة ع1ع5012212 » التي سنتعرف عليها بعد قليل. 
كما أن للوسيلة إل الخاصة بهذه الفئة العديد من الصيغ التي من المفيد أن 
نتعرف عليها: 


© إضافة 400: 
ضيف ماما إلى يماع اعات را ابيع اا 
-١‏ الصيغة الأولى تستقبل معاملا واحدا من النوع إمt .Sq1 ۴a4 ne‏ 
أ الضبيكة الثائية يشل اضيا بمكل اسم المدامل و إحدى قي ابرق 
yp‏ التي توضح نوع المعامل. 
۳- الصيغة الثالتة تزيد على الصيغة السابقة بمعامل ثالث من النوع 
مه يستقبل حجم البيانات التي ستوضع في المعامل. 
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:- الصيغة الرابعة تزيد على الصيغة السابقة بمعامل» يستقبل اسم عمود 
في مجموعة البيانات 1226251 ليربط المعامل به. 

8 هناك فة خاسة لكتها لم يعد من النتصوح اليتكدانها/ فقيل 
اسم المعامل» وكائنا 01ع[01 يحمل قيمته» وذلك بسبب التعارض بينها 
وبين الصيعغة الثانيةء لهذا تم إضافة وسيلة جديدة اسمها 
11W ith Value‏ كبديل لهذه الصيغة. 


إضافة بالقيمة :AddWithValue‏ 

تضيف معاملا إلى المجموعةء وهي تستقبل اسم المعامل» وكائنا زط0 
يحمل قيمته.. وتعيد هذه الوسيلة مرجعا إلى المعامل الذي تم إنشاؤه. 

لاحظ أنك تستطيع أن ترسل إلى المعامل الثاني لهذه الوسيلة قارئ بيانات 
01 أو جدول بيانات 12381816: لتتم قراءة كل الصفوف 
الموجودة فيهما ووضعها في المعامل.. هذا مفيد إذا كنت تتعامل مع إجراء 
مخزن يستقبل معاملا جدولا Para)‏ 18616-77211060: وتريد أن ترسل 
إليهجدولا كاملا. و متنا علبى هذا في اتروع 
25 --- في هذا المشر وع نقرأ جدول المؤلفين في 
قارئ بيانات من النوع 1ع016061(3431630» ثم نرسله كمعامل ثان إلى 
الوسيلة 010517715572116 لاستخدامه كمعامل للإجراء المخزن 
759 وبهذا نستطيع إضافة المؤلفين من قاعدة بيانات آكسيس 
إلى قاعدة بيانات سيكويل سيرفر. 

لاحظ أن قارئ البيانات يجب أن يظل مفتوحا هو والاتصال الذي يستنخدمهء 
لأن الوسيلة 800557158572106 لا تنسخ السجلات من قارئ البيانات فعلياء 
ولا يتم نسخ هذه السجلات إلا عند استدعاء الوسيلة ExecuteNonQuery‏ 
الخاصة بكائن الأمر الذي ينفذ الإجراء المخزن ويرسل إله المعامل الجدول. 


A۸ 


2-2 واجهة معامل البيانات IDataParameter Interface‏ 
هذه الواجهة معرفة في النطاق 57:51677.10262» وهي تمتلك الخصائص التالية: 


وخ اسم المعامل :ParameterName‏ 
تحدد اسم المعامل» مع ملاحظة أنه يبدأ بالرمز @» مثل ع0ة6©115611). 


هل هو منعدم ع1970011801: 
إذا جعلت قيمة هذه الخاصية ع11'» فسيقبل المعامل القيمة 011171111آ.. 
والقيمة الافتراضية هي ه1"815. 


أ الاتجاه :Direction‏ 
تحدد اتجاه المعامل» وهي تأخذ إحدى قيم المرقم مهناءء:61(1]عمتهءح2 التالية: 
Input‏ معامل إدخالء لإرسال قيمة إلى الاستعلام أو الإجراء المخزن. 
utp‏ معامل إخراج»لقراءة قيمة متغير إخراج من الإجراء 
المخزن.. هذا النوع غر متاح مع قواعد بيانات آكسيس! 
put utp‏ معامل إدخال وإخراج معا. 
6127/11 | قيمة عائدة من إجراء مخزن. 











وعا القيمة ue‏ [و۷: 

تقرأ أو تغير قيمة المعامل» وهي من النوع 06606 لتقبل أي نوع من القيم» 

لكن هذا لا يعني أن كل القيم مسموح بهاء لأن الخاصية »مرآ ط5 تحدد نوع 

القيم المسموح بها. 

ويجب وضع القيسة فى هذه الخاصصية قبل :تنفية الاستغلام سن خلال كان 

الأمرء وإذا كان المعامل للإخراج» فإن القيمة العائدة من الخادم توضع في هذه 

الخاصية بعد تنفيذ الأمر أو بعد إغلاق قارئ البيانات 12216201 إن كنت 

تستخدمه. 

ولوضع القيمة 1018177111 في هذه الخاصيةء استخدم الفئة 108111011 كالتالي: 
P.Value = DBNull.Value‏ 

حيث إن 7731116 هي خالصية مشتركة للقراءة فققط 

Shared ReadOnly Property‏ معرفة في الفئة 10811011 لتعيد نسخة 

جديدة من هذه الفئة تمثل القيمة 101311111. 


١ 

















و- النوع ٠ :Db Type‏ 
تحدد نوع المعامل» وهي تأخذ إحدى قيم المرقم عم1(0177 التالية: 


الثابت معناه مجال القيم أو طول المتغير 
SByte‏ وحدة ثنائية بإشارة. من -۱۲۸ إلى ۱۲۷ 
Byte‏ وحدة ثنائية موجبة. من ٠‏ 
الى هه ” 
Binary‏ بيانات ثنائية من ١‏ بايت 
إلى ۸۰۰۰ بايت 
Boolean‏ قيمة منطقية False‏ أو True‏ 
Int16‏ عدد قصير من ۳۲۷٦٣۸-‏ 
إلى ۲۲۷۹۷ 
N6‏ _ عدد قصير موجب من ٠‏ إلى ٠٠٠۴١‏ 
Int32‏ عدد صحيح من ۲۱٤۷٤۸۳٩١٤۸‏ 
إلى ۲۱٤۷٤۸۳٦٤۷‏ 
UlInt32‏ عدد صحيح موجب من ۰ 
إلى 4۲۹٤۹1۷۲۹۰‏ 
Int64‏ عدد طويل مز 


TYTTVTTTAOEVVOAN A 
qYYTTYY.۳1۸04۷۷9۸ ۰۷ إلى‎ 
إلى‎ ٠ عدد طويل موجب من‎ | 4 

كاده 5 “ا؟لا. :75 ة ١5‏ 
Single‏ عدد مفرد من ):5-55٠١( × ١,5‏ 
ال ”5 x‏ )۲۸۸1۰( 
بدقة ۷ خانات عشرية. 

من )۳۲٤-۸۱۰( × 5,٠‏ 
إلى ۱,۷ × (۳۰۸۸۱۰) 
بدقة ٠١‏ خانة عشرية. 
Currency‏ عملة من -۲ 5 19 إلى (۲ ۸ ١ )١١‏ 
بدقة ٤‏ خانات عشرية. 


Double‏ عدد مزدوج 






























































الثابت 
Decimal‏ 


VarNumeric 


Guid 

Time 

Date 
DateTime 


DateTime2 


DateTime 
Offset 
String 


StringFixed 
Length 


AnsiString 


AnsiString 
Fixed 
Length 
Xml 


Object 





معناه 
عدد عشري 


رقم 3 خد 


وقت 
تاريخ 
تاريخ ووقت 


تاريخ ووقت 





مجال القيم أو طول المتغير 
من ۱,۰ × (۲۸-۸۱۰) 
إلى ۷,۹ × (۲۸۸۱۰) 
بدقة تصل إلى ۲۸ خانة عشرية. 
قيمة رقمية متغيرة الطول» تقبل أيا 
من الأنواع السابقة. 


وقت بدون تاريخ 
تاریخ بدون وقت 
تقبل تواريخ بين ۱۷٥۲/۱/۱‏ 
و ۹444/1۲/۳۱ 
تقبل تواريخ بين ١/١/١‏ 
و ۹444/۲/۳۱ 


إزاحة الوقت والتاريخ 


۹۱ 





نص متغير الطول» مكون من 

حروف موسعة 1[810006. 
نص ثابت الطول» مكون من حروف 

موسعة ع1[121000. 
نص متغير الطول» مكون من 
حروف قياسية بترميز 450011. 
نص ثابت الطول» مكون من حروف 
قياسية بترميز 450011. 


أي نوع غير موجود في الأنواع 
السابقة. 





















































تو عمود المصدر 012 50111:60: 
تحدد اسم العمود في مجموعة البيانات 12343561 الذي سيتم ربطه بالمعامل.. 
هذا مفيد عند حفظ التغيرات من مجموعة البيانات إلى قاعدة البيانات باستخدام 
أمر التحديث 2201ددتد0©) 1101346].. هذه هي الخطوات التي تحدث: 
- يعرف أمر التحديث وجدم01 © 136م1] معاملا لكل عمود في 
مجموعة البيانات« ويضع اسم العمود في الخاصية 5011166000111 
لكل معامل. 
- عند تنفيذ عملية التحديث؛. يقوم موصل البيانات DataAdapter‏ 
بالمرور على صفوف مجموعة البيانات واحدا تلو الآخر وتنفيذ أمر 
القعديك کے كما علي هدة 
- لتحديث أي صف» يضع موصل البيانات في كل معامل من معاملات 
أمر التحديث» قيمة الخانة الموجودة في العمود المحدد في الخاصية 
512211010 وبهذا يمكن تنفيذ استعلام 
التحديث لكل صف بصورة صحيحة. 
وستفهم هذه الأمور بصورة أوضح عندما نتعرف على موصل البيانات 
3011 ومجموعة البيانات غ122]25©1. 


3 إصدار المصدر :Source Version‏ 
تحدد نوع القيمة التي ستوضع في المعامل.. هذا مفيد عند استخدام المعامل 
لتحديث مجمو عة البيانات» لأن كل خانة فى مجموعة البيانات تحتفظ بعدة 
أنواع من القيم» مثل القيمة الأصلية (القادمة من قاعدة البيانات)» والقيمة 
الحالية (القيمة الجديدة التي أدخلها المستخدم).. وتأخذ هذه الخاصية إحدى قيم 
المرقم 10342120181761510.. وسنتعرف على هذا الأمر بتفصيل أكبر لاحقا 

عند التعرف على مجموعة البيانات. 


4۲ 


5 واجهة معامل بيانات قاعدة البيانات 
IDbDataParameter Interface‏ 


هذه الواجهة ترت الواجهة إعاعصهإه۴هاه10ء وهي تمتلك بعض الخصائص 
الإضيافية التي تضرف مزينذا سق التحكم فى القيم:التى لها المعامل.. رخا 


“ل الحجم :S¡e‏ 
تحدد أقصى حجم مسموح به للمعامل بالوحدة الثنائية 8356.. والقيمة 
الافتراضية لهذه الخاصية تستنتج من نوع المعامل» فإن كان عددا صحيحا 
على سبيل المثال» تكون قيمتها ٠٤‏ وإن كان المعامل يحتوي على مصفوفة فإن 
هذه الخاصية تأخذ طول المصفوفة.. لاحظ أنك لو صغرت قيمة هذه الخاصية 
عن حجم البيانات» فسيتم أخذ جزء من هذه البيانات فقط وإسقاط الجزء الزائد. 


"ل الدقة بروزوزمعمرم: 
تحدد أكبر عدد مسموح به من الخانات الرقمية في القيمة التي يقبلها المعامل.. 
والقيمة الافتراضية هي ٠٠‏ وهي تعني عدم فرض قيود على عدد الخانات» 
وترك ذلك لمزود قاعدة البيانات. 


المقیاس 50216: 
تحدد أكبر عدد مسموح به من الخانات العشرية في القيمة التي يقبلها 
المعامل.. ولو زاد عدد الخانات عن هذا الرقم يتم تقريبه.. والقيمة الافتراضية 
هي ٠‏ . 


۹۲۳ 


2 فنة معامل قاعدة البيانات DbParameter Class‏ 


هذه الفئة معرفة في النطاق 011101 53751612.1(0218.0» وهي فئة أساسية مجردة 
تجب وراثتهاء تمثل الواجهة 1ع11(51(342221861 مما يعني أنها تمثل أيضا 
الواجهة وهع1ع110382212» وبالتالي فهي تملك كل خصائصهماء ولا تزيد عليها 
إلا خاصية واحدة جديدة وهي: 


= تمثيل قيمة منعدمة في عمود المصدر :SourceColumnNulIMapping‏ 

إذا جعلت قيمة هذه الخاصية مuإ1»‏ فسيعني هذا أن هذا المعامل يستخدم 
لإخبارك إن كان عمود المصدر 00[11100ء0:ن50 في مجموعة البيانات 
فارغا أم لاء حيث تكون قيمة المعامل ٠‏ إن كان العمود فارغاء وتكون 
قيمته ١‏ إن كان العمود يحتوي على أي قيمة.. هذا مفيد عند تعريف 
استعلامات التحديث» لأن مقارنة أي خانتين قيمتهما 71711 تكون نتيجته 
6 رغم أن الخانتين متساويتين فعلا!.. لهذا يجب أن نتأكد قبل إجراء 
المقارنة إن كانت الخانتين فارغتين أم لا.. وسنرى كيف نستخدم هذه الطريقة 
عند التعرف على موصل البيانات في فصل لاحق. 


كما تمت تمتلك هذه الفئة وسيلة واحدة وهي. 


7# تصفير النوع Type‏ bۆResetD:‏ 
تعيد الخاصية مم رآ ط5 إلى قيمتها الافتراضية. 


والفئات التالية ترث هذه الفئة: 
OdbcParameter Class .١‏ 
؟. OleDbParameter Class‏ 
SqlParameter Class ."‏ 
؟. OracleParameter Class‏ 


وسنقتصر هنا على التعرف على الفئة 1عاع0:ة50121. 


١ 


4 فئة معامل سيكويل SqIParameter Class‏ 


هذه الفئة ترث الفئة :1ع1ع1(62210» وهي تمثل معامل استعلام موجه إلى 
سيكويل سيرفر. 

ولحدث إنشاء هذه الفئة سبع صيخعء الصيغة الأولى بدون معاملات» والصيغ 
الأخرى تتيح لك إمداد المعامل ببعض قيم خصائصه» مثل اسم المعامل ونوعه 
واتجاهه.. إلخ.. على سبيل المثال» تستقبل الصيغة السابعة ١١‏ معاملا هي 
بالترتيب: 


انت امال 
إحدى قيم المرقم ©6م501106157 توضح نوع المعامل. 

عدد صحيح يوضح طول المعامل إذا كان نصا أو وحدات ثنائية 8365.. 
اقسا للمعاملات العدكية استكدم اة طق وا كان المعافل من 
الأنواع القصوى (×1۸))» فاستخدم القيمة .١-‏ 

إحدى قيم المرقم ١0اءع۲51۲ءعع‏ ”هم۴ التي توضح اتجاه المعامل. 

وحدة ثنائية 783:6 توضح عدد الخانات العشرية للمعامل الرقمي (الخاصية 
.(Precision‏ 

وحدة ثنائية 18376 توضح عدد خانات التقريب العشري للمعامل الرقمى 
(الخاصية 56216). 

اسم عمود المصدر في مجموعة البيانات» الذي سيأخذ منه المعامل قيمته. 
إحدى قيم المرقم 1(3131501717761510: توضح إصدار العمود في 
مجموعة البيانات.. وسنتعرف على هذا المرقم في فصل لاحق. 

قيمة منطقيةء إذا جعلتها م1۲٠‏ فستكون وظيفة معامل البيانات أن يتأكد أن 
العمود ليس فارغا 71111 في مجموعة البيانات» حيث تكون قيمة المعامل ٠‏ 
إذا كان العمود فارغاء وتكون قيمته ١‏ إذا لم يكن فارغا. 

كائن :0و0 يحمل القيمة التي تريد تمريرها إلى المعامل.. وعليك أن 
تستخدم القيمة عتزنط]3210 إذا كان المعامل يقرأ القيمة من مجموغة 
البيانات. 

نص ترسل قيمته إلى الخاصية ع0015161120001162110210212125كة 
التي سنتعرف عليها لاحقا. 

نص تر سل قيمت هه [لل ي الخاص ية 
Xm ]SchemaCo1ectionOwningSchema‏ التي سنتعرف عليها لاحقا. 
نص ترسل قيمته إلى الخاصية XmlSchemaCollectionName‏ التي 
سنتعرف عليها لاحقا. 


وهناك صيغة تستقبل فقط أول أربعة معاملات من الصيغة السابقة» وفي هذه الحالة 
يكون اتجاه المعامل للإدخالء ويق رأ القيمة الحالية للسجل 


4° 


..urrent Value‏ وهناك صيغة أخرى تستقبل كل معاملات الصيغة السابقة ما 
عدا آخر ثلاثة معاملات. 
والكود التالي يعرف معاملا يقرأ قيمته من الحقل 8001 في مجموعة البيانات: 
Dim PrmBook As New SqIParameter("@Book",‏ 
SqIDbType.NVarChar, 0, "Book")‏ 
والكود التال بعر ف معاملا باخ قمثه من النسخة الأضاية للحقل (11 فى مجموعة 
ET‏ : 
Dim PrmID As New SqlParameter('"@Original ID",‏ 
SqIDbType.Int, 0, ParameterDirection.Input, False, 0,‏ 
"ID", DataRowVersion.Original, Nothing)‏ ,0 
ويمكنك استخدام هذين المعاملين لتعريف أمر التحديث ململ كالتالي: 
Dim UpdateCmd As New SqlCommand‏ 
UpdateCmd.CommandText = "UPDATE Books " & _‏ 
"SET Book = @Book WHERE ID = @Original ID"‏ 
UpdateCmd.Connection = Me.SqIConnection1‏ 
UpdateCmd.Parameters.AddRange(‏ 
New SqlIParameter( ) {PrmBook, PrmID})‏ 
ويمكنك جعل هذا الأمر أمر التحديث الخاص بموصل البيانات كالتالي: 
DaAuthorBooks.UpdateCommand = UpdateCmd‏ 
وستجد هذا الكود في حدث تحميل النموذج 1.0304 في المشروع 
1ew 55‏ .. ويمكنك نقل التغييرات من مجموعة البيانات إلى قاعدة 
البيانات بضغط زر الحفظء حيث يقوم موصل البيانات 103/41101130015 بتنفيذ 
الوسيلة «Update‏ التي تستخدم أمر التحديث والمعاملات التي عرفناها. 
وإضافة إلى ما ترثه من الفئة الأمء تمتلك الفئة SqlIParameter‏ الخصائص التالية: 


37 المعرف المحلي 1.0031610: 
E‏ تقاف العو للد لدي SS‏ المحااص ا في لاسي يه 
هو: 0x0001‏ اكع كتاب: "برمجة إطار لعل للمزيد من التفاصيل 
عن الثقافات العالمية ومعرفاتها). 


۹٩ 


وخ معلومات المقارنة 21:1210م2:ه©: 
تحدد كيف سيقوم هذا المعامل بمقارنة النصوصء وهي تأخذ إحدى قيم المرقم 
5 (انظر الملحق رقم .)١‏ 


وخا الإزاحة :Offset‏ 

تحدد موضع بداية القراءة من الخاصية عں آج۷ .. وتقاس الإزاحة بعدد 
الوحدات الثنائية و8536 عند التعامل مع بيانات ثنائية» وبعدد الحروف 
5 عند التعامل مع نصوص.. والقيمة الافتراضية هي ٠٠‏ أي أن 
القراءة تتم من بداية البيانات. 

وتحدد الخاصية 926 عدد الحروف أو الوحدات الثنائية التي ستتم قراءتها 
بدءا من الموضع 6t‏ .. هذا مفيد اذا وضعت في اا Value‏ كما 
كبيرا من البيانات» وأردت تجزئتها دون الحاجة إلى متغيرات وسيطة وحيل 
برمجية ملتوية.. في هذه الحالة ستعطي للخاصية غ01456) مبدئيا القيمة صفر 
وللخاصية ه512 الطول الذي تريده (وليكن 3 ..)١‏ بعد هذا تستخدم حلقة 
تكرار Loop‏ تنفذ فيها الأمر على قاعدة البيانات (حيث سيقرأ الأمر الجزء 
المحدد فقط في المعامل بدءا من الموضع et‏ وبالطول «(Size‏ ومن ثم 
تزيد قيمة الخاصية tعءOf‏ بمقدار ١٠‏ لقراءة جزرء تال. . ويستمر الدوران 
وتنفيذ هذه العملية إلى أن تتجاوز طول البيانات الموجودة في الخاصية 
عنالة7.. لاحظ أن هذه الطريقة مناسبة للاستخدام فقط مع الأمر 
Write‏ . 1100316].. وستجد مثالا على هذا في الزر Param e†e۲.0 ۴5٥‏ في 
المشروع 10318 1.3186 ع7171: وهو يسمح لك بإضافة صورة شعار في 
العمود 1,0502 للناشر الثاني.. لاحظ أننا حملنا كل محتويات ملف الصورة 
مرة واحدة ووضعناها في الخاصية 77106 للمعامل» ومن ثم أرسلناها إلى 
قاعدة البيانات على أجزاء صغيرة.. هذه الطريقة تحتوي على عيب كبيرء 
وهو أن الصورة إذا كانت ضخمة جداء فستستهلك مساحة كبيرة من الذاكرة 
وقد تسبب بطء البرنامج.. لهذا لا تستخدم هذه الطريقة إلا إذا كان حجم 
الصورة معقولاء أما إذا كان ضخماء فالأفضل أن تحمل أجزاء من الملف 
وترسلها إلى قاعدة البيانات بالطريقة التي استخدمناها في الزر 11003816 
ع7 . في نفس البرنامج. 


4۷ 


وا نوع بيانات سيكويل :SqIDbType‏ 

تحده ضرع المعامل من + بين أنواع البيانات في سيكويل سيرفرء وهي تأخذ 
إحدى قيم المرقم 6م:ز9015261؛ وهي تحمل نفس أسماء أنواع بيانات 
سيكويل سيرفر التي تعرفنا عليها بالتفصيل في الفصل الثالث.. والقيمة 

الافتراضية لهذه الخاصية هي جا ٣إNVa.‏ 
لاحظ أن هذه الخاصية مرتبطة بالخاصية مرآ طا( لهذا لو غيرت قيمة 
إحداهما فستتغير الأخرى تلقائياء بحيث تحتوي الخاصية 50110615006 دائما 
على أنسب نوع من أنواع سيكويل سيرفر يوافق نوع المتغير الموجود في 

الخاصية 6م1(5157.. جرب مثلا: 

Dim 2 As New SqIParameter 
P.SqlIDbType = SqIDbType.Money 
MsgBox(P.DbType.ToString("g")) ' Currency 
P.DbType = DbType.Int64 
MsgBox(P.SqIDbType.ToString("g")) ' BigInt 


3 اسم النوع :TypeName‏ 

إذا كنت تستخدم المعامل لإرسال قيمة إلى معامل جدول أ عں ]ج ۷-م[طه1؛ 
فضع اسم هذا النوع في هذه الخاصيةء متضمنا اسم المالك ۲مم س0.. فمثلاء 
للتعامل مع النوع AuthorType‏ الذي يستخدمه الإجراء المخزن 
75 :؛ وضعنا في هذه الخاصية النص "dbo.AuthorType"‏ 
أو باختصار "عم110115ل' ' لأن المالك هنا افتراضي.. وفي هذه الحالة لا 
بد ان نضع في الخاصية عم501106157 القيمة ..SqlDbType.Structured‏ 
وهذا هو ما فعلناه في المشروع .TableValuedParameters‏ 


ا اسم المتغير الخاص بالمستخدم :UdtTypeNamıe‏ 
إذا كنت تستهدم المعامل لأزينال قيمة إلى نوع من تعريقه السنتكدم 11462 
190 0م212 فضع اسم هذا النوع في هذه الخاصية»ء ولا تنس أن تضع 
في الخاصية عم501106157 القيمة 5011(6179706.1706.. وسنتعرف على 
المتغيرات التي يعرفها المستخدم في سيكويل سيرفر لاحقا. 


لأا قيمة سيكويل 106ه50157: 
مماثلة للخاصية 25872106 وكلتاهما تقرأ أو تغير قيمة المعامل. 


۹۸ 


57 يوز قاعدة بيانات المخطط :XmlSchemaColIlection Database‏ 
تعيد اسم قاعدة البيانات التي توجد بها مجموعة مخططات ,آ2001.. وإذا 
كانت قيمة هذه الخاصية نصا فارغاء فهذا معناه أن المخططات توجد فى 
قاعدة البيانات الحالية» أو أنه لا توجد مخططات أصلاء وفي الحالة الأخيرة 
مس تتكون قيممسة الخالصيتين XmlSchemaCollectiooName‏ 
و Xm ]SchemaCollectionOwningSchema‏ نصا فار غا. 


فط اسم مجموعة المخططات :XmlSchemaCollectionNane‏ 
تعيد اسم مجموعة مخططات ,21/1. 


:XmlSchemaCollectionOwningSchema كلظ‎ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


1ك 


— “N 


قارئ البيانات 1021214620161 


يتم إنشاء قارئ البيانات Data Reader‏ باستدعاء الوسيلة ExecuteReader‏ 
الخاصة بكائن الأمر 0164© 21820ة00©.. ويستقبل قارئ البيانات نتيجة 
الاستعلام الذي ينفذه كائن الأمرء ويقوم بتخزين ما يصل من البيانات من الخادم في 
المخزن الوسيط للشبكة 18114 7216011 الموجود على جهاز العميل» حيث 
يمكنك المرور عبر السجلات المستلمة واحدا تلو الآخر على التوالي» مما يوفر 
ميزتين هامتين: 
-١‏ السرعة: حيث يمكنك قراءة السجلات المتوفرة فور وصولهاء دون انتظار 
اكتمال وصول كل السجلات أولا. 
-١‏ عدم استهلاك الذاكرة: لأن قارئ البيانات يحتفظ بسجل واحد فقط في 
الذاكرة فى كل مرة. 
لكنّ لهذه الطريقة عيبين أساسيين: 
-١‏ عدم القدرة على تحديث سجلات قاعدة البيانات.. بعبارة أخرى: قارئ 
البيانات للقراءة فقط كما يقول اسمه» وليس للكتابة! 
-١‏ عدم القدرة على التراجع إلى الخلف» أو القفز مباشرة إلى سجل في موضع 
معين في النتيجة دون المرور على ما قبله من السجلات. 
لهذا يوصف قارئ البيانات بأنه "مجرى بيانات للأمام فقط وللقراءة فقط": 
Forward-only, Read-only Stream.‏ 
لكل هذاء يمكنك استخدام قارئ البيانات في الحالات التالية: 
-١‏ لو كنت ستتعامل مع سجلٌ واحد فقط. 
- لو كنت ستقرأ كل سجل مرة واحدة فقطء ولا يعنيك الرجوع إليه مرة 
أخرى. 
#ب لی كانت قاعةة الائات موجودة على تفش الجساز »هما يعن سوعة 
الحضيول على ادات متها مواشرة+ دون بالحاحة إلى تصرليا :في الذاكوة: 
-٤‏ عندما تريد قراءة النتائج دون الحاجة إلى تغيير أي جزء منها في قاعدة 
البيانات 


د واجهة الييانات IDataRecord Interface‏ 


تقدم هذه الواجهة الخصائص والوسائل اللازمة لقراءة محتويات السجل الحالي في 
قارئ البيانات. 
وتمتلك هذه الواجهة الخاصيتين التاليتين: 


57 فز عدد الحقول :Field Count‏ 
تعيد عدد الأعمدة في السجل.. هذا يتيح لك كتابة حلقة تكرار م1.00 للمرور 
عبر كل الأعمدة بدءا من العمودرقم صف إلى العمودرقم 
1 - 11610100106.. هذا مفيد لاختصار الكود عندما تستخدم استعلام يعيد 
عددا كبيرا من الحقول. 


7 ف العنصر 22رع16: 
هذه هي الخاصية الافتراضية «Default Property‏ وهي تستقبل رقم العمود 
أو اسمه كمعامل» وتعيد كائنا Object‏ يحتوي على القيمة الموجودة في 
السجل الحالي في هذا العمود.. والمثال التالي يعرض قيمة الخانة الاولى في 
الصف* 
MsgBox(Reader.Item(0))‏ 
أو باختصار: 
MsgBox(Reader(0))‏ 
كنا تمتلك. هذه الو اجية الوسائل الثائية: 
7# معرفة الاسم :GetName‏ 
أرسل إلى هذه الوسيلة رقم العمود» لتعيد إليك اسمه. 
7# معرفة الترتيب 600701081 6©: 
أرسل إلى هذه الوسيلة اسم العمودء لتعيد إليك رقمه. 


5 معرفة نوع الحقل :GetField Type‏ 
أرسل إلى هذه الوسيلة رقم العمود, لتعيد إليك كائن النوع 6م:13' الذي يمثل 


َذ# 


معرفة اسم نوع البيانات 11206 م0)12212179: 
أرسل إلى هذه الوسيلة رقم العمودء لتعيد إليك نصا يمثل اسم نوع بياناته. 


© معرفة القيمة 00572116 ©: 
أرسل إلى هذه الوسيلة رقم العمودء لتعيد إليك كائنا 1م066 يحتوي على 
الع المووجودة في السبخل الحالي فى .هذا العمود, 


2# معرفة القيم و116ه00)57: 

أرسل إلى هذه الوسيلة مصفوفة كائنات 41383 01 0[6» ليتم ملؤها بالبيانات 
الموجودة في خانات الصف الحالي في قارئ البيانات.. لاحظ أنك لو أرسلت 
مصفوفة أقصر من عدد خانات الصف الحالي فلن يحدث خطأء بل سيتم نسخ 
جزء من الخانات فقط إلى المصفوفة وإهمال الباقي.. أما لو أرسلت مصفوفة 
أطول من عدد خانات الصف الحاليء فسيتم نسخ كل الخانات إلى جزء من 
المصفوفة وترك باقي المصفوفة فارغا.. وفي كل الأحوالء تعيد هذه الوسيلة 
عدد الخانات التي تم نسخها إلى المصفوفة. 


2# قراءة الوحدات الثنائية ومر8)ء6: 
تستخدم عندما يكون قارئ البيانات تتابعيا 560116714121» وهي تعيد مصفوفة 
وحدات ثنائية وم ر8› تحتوي على البيانات الموجودة في أحد الأعمدة.. ولهذه 
الوسيلة المعاملات التالية: 
- رقم العمود. 
- موضع بداية القراءة من محتويات العمود. 
- مصفوفة وحدات ثنائية و83:6 لاستقبال البيانات.. لاحظ أن خطأ 
سيحدث لو كانت المصفوفة أقصر من البيانات المطلوبة. 
- موضع بداية الكتابة في المصفوفة. 
- عدد الوحدات الثنائية Bytes‏ المطلوب قراءتها من محتويات العمود. 
بدءا من الموضع المحدد في المعامل الثاني.. لاحظ أن خطأ سيحدث لو 
كان الطول المطلوب أكبر من البيانات المتبقية في العمود. 
وتعيد هذه الوسيلة عدد الوحدات التي تم نسخها إلى المصفوفةء ولو أرسلت 
إلى هذه الوسيلة مصفوفة فارغة عمنط810» فستعيد إليك العدد الإجمالي 
للوحدات الثنائية المتاحة في الخانة. 
وقد استخدمنا هذه الوسيلة في المشروع 163013185610248 لقراءة بيانات 
الصورة» حيث نقرأ ٠٠١‏ وحدة ثنائية 1836 من بداية الصورة ونحفظها في 
الملف» ثم نقرأ ١٠‏ وحدة تالية ونحفظها في الملف» ونستمر في فعل هذا إلى 
أن نكمل قراءة الصورة. . لاحظ أن شرط التوقف عن القراءةت هو أن تكون 
القيمة العائدة من الوسيلة و183:]6© 6 أصغر من عدد البيانات الذي طلبنا 
قراءته» مما يعني أن هذه هي آخر بيانات متاحة في الخانة. 


ف 


قراءة الحروف 121:5 )6 0: 


تستخدم عندما يكون قارئ البيانات تتابعيا 560116014121»: وهي تعيد مصفوفة 
حروف 4811338 2۲ط تحتوي على الحروف الموجودة في عمود نصي» وهي 
ممائلة للوسيلة السابقة في المعاملاث والقيمة العائدة فيمًا عذا أن المعامل 


الثالث يستقبل مصفوفة حروف بدلا من مصفوفة الوحدات الثنائية. 


هل القيمة منعدمة 151(131001[1: 


تعيد 706 إذا كانت الخانة التي أرسلت رقمها كمعامل فارغة 126111111.. 
لاحظ أن عليك استخدام هذه الوسيلة قبل محاولة قراءة قيمة أي خانة»ء فقارئ 
البيانات يسبب خطأ إذا كانت قيمة الخانة ر[.721[1.. هكذا متلا يمكنك محاولة 


قراءة الخانة الموجودة في العمود الأول في الصف الحالي: 


If Not Reader.IsDBNull(0) Then MsgBox(Reader(0)) 


كما تمتلك هذه الواجهة عددا من الوسائل التي تستقبل رقم العمودء وتعيد قيمة 
الخانة الموجودة في هذا العمود في الصف الحالي.. وتختلف هذه الوسائل في نوع 
القيمة العائدة منهاء حيث تقوم كل منها بتحويل بيانات الخانة إلى أحد أنواع إطار 


العمل الأساسية؛ كما هو موضح في الجدول التالي: 





وتسبب هذه الوسائل خطأ في البرنامج إذا فشلت في تحويل البيانات إلى النوع 


جه أن انع انع انع انع نت انع اح حت أنه انيه 


الوسيلة 
GetByte‏ 
GetChar‏ 
GetBoolean‏ 
GetInt1 6‏ 
GetInt32‏ 
GetInt64‏ 
GetFloat‏ 
GetDouble‏ 
GetDecimal‏ 
GetDate Time‏ 
GetString‏ 
GetGuid‏ 





المطلوب. 





النوع الذي تعيده 
وحدة ثنائية ع)/83. 
حرف 01213. 
قيمة منطقية 0هع8001. 
عدد قصير 51016. 
عدد صحيح 1ع8ع1216. 
عدد طويل ع0م.آ. 
عدد مفرد ع1اع510. 
عدد مزدوج ©1201101. 
عدد عشري 106012121. 
تاريخ ووقت 131206ء12031. 
نص ٣g‏ ااSt.‏ 
سجل المعرف المتفرد .Guid Structure‏ 















































4 فئة سجل البيانات Class‏ :10212242126201 


هذه الفئة تمثل الواجهة 11034316010: وهي تمتلك كل وسائلها وخصائصها دون 
أن تزيد عليها شيئا. 

رتك هذه النكة تمر اج افد رور عبر سملا قارئ الباناك كنا 
سنرى لاحقا. 


© واجهة قارئ البيانات Interface‏ :11224212620163 


ترث هذه الواجهة كلا من الواجهتين [Disposable‏ و .IDataRecord‏ 
اشا إلى ما تركه من كاتس شتلك هذه الو احهة الك اض :الحديية القالدة: 


57 وز العمق طامء5: 
تعيد رقما يمثل عمق الجدول الحاليء إذا كانت النتيجة تحتوي على جداول 
متداخلة (خانات بها جداول» بها خانات بها جداول... إلخ)» مع ملاحظة أن 
الجدول الخارجي يكون عمقه صفراء وأول جدولا داخلي عمقه ١‏ ... وهكذا. 


فط هل هو مغلق 150010560: 
تعيد ون[ إذا تم إغلاق قارئ البيانات. 


57 فز السجلات المتأثرة :RecordsAffec(ed‏ 
تعيد عدد الصفوف التي تأثرت بأوامر الإضافة أو التحديث أو الحذف.. وتعيد 
هذه الوسيلة ٠‏ إذا لم تتأثر أية سجلات أو فشل تنفيذ الاستعلامء 
لاحظ أن هذه الخاصية لا تعطيك القيمة الصحيحة إلا بعد إغلاق قارئ 
البيانات» لهذا عليك أن تتأكد أولا أن للخاصية 19010560 القيمة عuإ»‏ 
أو تستخدم الخاصة إع†ءم؟۸AءلإهدRec‏ بعد استخدام الوسيلة ©1056[ ©. 


كما تمكلك هذه الواجهة هذه الوسائل الجديدة: 


2# قراءة :Read‏ 
تجعل قارئ البيانات ينتقل إلى السجل التالي» وتعيد ..٣ ٥‏ أما إذا كان 
السجل الحالي هو آخر سجل ولا يوجد سجل تال» فإنها تعيد 212156 وعليك 

التوقف عن القراء فى هذه الحالةء وإلا حدث خطأ. 
لاحظ أن قارئ البيانات يشير مبدئيا إلى السجل رقم -1؛ أي أنه يشير إلى 
السجل السابق لأول سجل» وهذا سيجعل محاولة القراءة تسبب خطأ فى 
البرنامج» حيث ستخبرك رسالة الخطأ أن هذه محاولة غير مسموح بها للقراءة 
بينما لا توجد بيانات حاليا: 
Invalid attempt to read when no data is present.‏ 
لهذا عليك استدعاء الوسيلة 11630 أولا للانتقال إلى أول سجل وقراءته» ثم 
الاستمرار في استدعائها إلى أن تعيد مءإه۴ء وذلك على الصيغة التالية: 
Do While Reader.Read‏ 
الكود اللازم لقراءة السجل الحالي ' 
Loop‏ 


2# النتيجة التالية :NextResult‏ 
عند استخدام كائن الأمر لتنفيذ أكثر من جملة .501 أو تنفيذ إجراء مخزن 
يعيد أكثر من نتيجة» فإن قارئ البيانات يشير مبدئيا إلى أول نتيجةء وعليك 
بعد قراءة كل سجلاتها أن تستخدم هذه الوسيلة لجعل قارئ البيانات يشير إلى 
النتيجة التالية.. وتعيد هذه الوسيلة م1 إذا وجدت نتيجة تاليةء لهذا عليك أن 
تستمر في استدعائها إلى أن تعيد 1:3156: وذلك على الصيغة التالية: 

Do 

Do While Reader.Read 

الكود اللازم لقراءة السجل الحالي ' 

Loop 

Loop While Reader.NextResult 


7# قراءة جدول المخطط bleؤGetSchema7Ta:‏ 
تعيد كائن جدول 10321216 فارغا يحتوي على مخطط النتيجة التي يتعامل 
معها قارئ البيانات.. وسنتعرف على كائن الجدول لاحقا. 
لاحظ أن المخطط يبحتوي على اسماء الأعمدة وأنواع بياناتها وأحجامها.. 
ويمكنك أن ترى هذا المخطط بشكل عملي في المشروع 16ا501611218.. 
في هذا المشروع استخدمنا قارئ بيانات ليحمل جدول المؤلفين» واستخدمنا 
الوسيلة 06150161712:12116) للحصول على مخطط جدول المؤلفين» 


وعرضناه في جدول عرض البيانات 103120011057161 الذي سنتعرف عليه 
بالتفصيل في فصل لاحق. 


7# إغلاق عو10©: 

تغلق قارئ البيانات.. هذا ضروري لتحرير كائن الاتصال المرتبط بقارئ 

البيانات» لأنك لن تستطيع استخدام كائن الاتصال في أي عملية أخرى طالما 

كان قارئ البيانات يستخدمه. 

وكما ذكرنا من قبلء لو أنشأت قارئ البيانات باستخدام الوسيلة 

1 بالصيغة التالية (حيث لم٥‏ هو اسم كائن الأمر): 
Dim Dr = Cmd.ExecuteReader(‏ 

CommandBehavior.CloseConnection) 
فإن كائن الأمر ا5 سيقوم بإغلاق الاتصال بقاعدة البيانات تلقائيا بمجرد‎ 
استدعاء الوسيلة عو010.‎ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


42 فئة قارئ البيانات Class‏ 121224212620161 


هذه الفئة أساسية مجردة تجب وراثتهاء وهي موجودة في النطاق: 
System. Data.Common‏ 
وتمثل هذه الفئة الواجهة لهه 150۸ء مما يعني أنها تمثل أيضا الواجهتين 
04 و eاDisposab]..‏ كما أنها تمثل أيضا واجهة القابلية للعد 
»]Enumerable‏ مما يعني أنها تمتلك الوسيلة 6417111612401 التي تعيد عدادا 
يمر عبر سجلات النتيجة واحدا بعد الآخرء مع ملاحظة أن كل عنصر في هذا 
العداد هو من نوع الفئة 1(5103121160010.. لهذا تستطيع المرور عبر سجلات 
قارئ البيانات باستخدام الوسيلة 12620 كما شرحنا سابقاء أو باستخدام حلقة التكرار 
Each‏ ۴ على الصيغة التالية: 
For Each R As DbDataRecord In Dr‏ 
MsgBox(R(0).ToString( ))‏ 
MsgBox(R([).ToString( ))‏ 
Next‏ 
هذا الكود سيعرض محتويات أول وثاني حقل في كل سجل من سجلات قارئ 
البيانات» بافتراض أن قارئ البيانات اسمه إ5 وأن النتيجة بها حقلان أو أكثر. 
وإضافة إلى ما ترثه من خصائصء تمتلك الفئة 126103121063001 الخاصيتين 
الجديدتين التاليتين: 


57 فز به صفوف 112912015: 
تعيد ع1" إذا كان قارئ البيانات يتعامل مع نتيجة بها صفوف. 


9 فين عدد الحقول المرئية :VisibleFiel 4 Count‏ 
تعيد عدد الأعمدة غير الخفية في قارئ البيانات. 


كما تمتلك هذه الفتة الوسائل الجديدة التالية: 


1#> معرفة نوع الحقل طبقا للمزود :GetProviderSpecific Field Type‏ 
أرسل إلى هذه الوسيلة رقم العمودء لتعيد إليك كائن النوع ممرآ الذي يمثل 
نوع بياناته.. هذا النوع لن يكون من أنواع إطار العمل الأساسية» بل سيكون 
من الأنواع الخاصة بمزود البيانات.. على سبيل المثال» لو كنت تتعامل مع 
مزود سيكويل سيرفرء وكان العمود يحتوي على نصوصء فإن هذه الوسيلة 
ستعيد كائنا يمثل نوع الفئة عمخ5015 وليس الفئةع5)10. 


#> قراءة القيمة طبقا للمزود :GetProviderSpecific Value‏ 
أرسل إلى هذه الوسيلة رقم العمودء لتعيد إليك كائنا مع ز0 يحمل قيمته.. 
لاحظ أن هذه القيمة ستكون من الأنواع الخاصة بمزود البيانات» لهذا سيسبب 

المثال التالي خطأ (بافتراض أن العمود رقم صفر عمود نصي): 
Dim Name As String = Dr.GetProviderSpecificValue(0)‏ 
MsgBox(Name)‏ 

والصواب أن تستخدم الكود التالي: 

Dim Name As SqlString = Dr.GetProviderSpecificValue(0) 
MsgBox(Name. Value) 


#ا> قراءة القيم طبقا للمزود :GetProviderSpecific Values‏ 
أرسل إلى هذه الوسيلة مصفوفة كائنات 1123 014ء[0)» لتملأها لك ببيانات 
الضف الحالي فى قارئ اتات :وكيد هذه الرس عند الكاناك اى ت 
لها فى الس ةة 


والفئات التالية ترث الفئة :DbDataReader‏ 

DataTableReader Class -١ 

OdbcDataReader Class -" 

OleDbDataReader Class -Y 

SqIDataReader Class -“ 

OracleDataReader Class -5‏ 
وسنكتفي هنا بالتعرف على الفئة :5011(343163016©1: وسنتعرف في فصل لاحق 
على .DataTableReader ill‏ 


42 فئة قارئ بيانات سيكويل SqIData Reader Class‏ 


هذه الفئة ترث الفئة :1010232162063 بكل وسائلها وخصائصهاء وهي تمكنك 
من قراءة البيانات القادمة من خادم سيكويل. 

ولي ليذه الئئة حددث إنشاء» ولكدك سام الحصيول عل فة نيا امعط 
الوسيلة ع16126201ا0ع:8 الخاصة بأمر سيكويل لم02 .S1‏ 

ولا تمتلك هذه الفئة أية خصائص جديدة غير ما ترثه من الفئة الأم» ولكنها تمتلك 
العديد من الوسائل الجديدة» وهي تقوم بقراءة البيانات من العمود الذي أرسلت رقمه 
إليها كمعامل» وتحولها إلى نوع البيانات المطلوب.. ولأسماء هذه الوسائل الصيغة 
العامة ‘GetX‏ حيث > هو اسم نوع البيانات الذي سيتم التحويل إليه.. وهذه 


الوسائل هي 

GetSqlBoolean >09 eB 5 
GetSqlBytes 2# GetSqlByte > 
GetSqlDateTime 2j GetSqlChars 2# 
GetSqlDouble =i GetSqlDecimal >19 
GetSqllnt1l6 > GetSqlGuid > 
GetSqlInt64 j GetSqlInt32 > 
GetSqlSingle 4# GetSqlMoney 7# 
GetSqIValue > GetSqlString 3# 
GetSqlXml >19 GetSqlValues >99 
GetTimeSpan zf 


على سبيل المثالء» الوسيلة 0645018102157 تعيد كائنا من النو ع «SqlBinary‏ 
وهي مناسبة لقراءة الأعمدة التي تحتوي بيانات من النوع image‏ ¡ أو 
A ×)‏ varbinary)M»ء‏ لهذا استخدماها في الزر 0615012810818 في المشروع 
1-8 لقراءة صورة أول ناشر من العمود 10802 (ويمكنك 
استخدامها أيضا للقراءة من العمود مع1,0])» وحفظها في ملف.. لاحظ أن عملية 
القراءة ستتم هنا بطريقة مباشرة (غير تتابعية)» وأن حجم الصورة سيؤثر على 
كفاءة هذه العملية, فلو كانت ضخمة فسيأخذ نقلها وقتا طويلاء وسيتم تحميلها في 
الذاكرة كاملة قبل حفظها في الملف! 

أما الوسيلة و6650113376 فستجد مثالا على استخدامها في الزر 
40 في المشروع 12620131861(318.. في هذا الكود 
استخدمنا الوسيلة و06150183:6 لقراءة مصفوفة محتوى التعاملات 
Transaction Context‏ . 


بهذا نكون قد أكملنا تعرفنا على قارئ البيانات.. وللتدريب على ما تعلمناه حتى 
الآن» يمكنك فحص المشروع 411011900125_1062061.. في هذا المشروع 
نسمح للمستخدم بكتابة اسم المؤلف في مربع نصء وعندما يضغط الزر 
"عرض الكتب"» نستخدم قارئ البيانات لكتابة كتب هذا المؤلف في مربع نص 
متعدد الأسطر. 

لا تنس نسخ قاعدة بيانات الكتب من القرص الضوئي إلى المحرك :© والتأكد من 
أنها ليست للقراءة فقطء لكي يعمل المثال بشكل صحيح. 


ملحوظة: 
لاستخدام الإجراء المخزن 411]501130015]© 0 للحصول على كتب المؤلف 
الذي ترسل إلى هذا الإجراء اسمه كمعامل» أجر التعديلات التالية على المشروع 
:AuthorBooks Reader‏ 
- ضع في الخاصيّة 1٥×٤‏ ,2ه الخاصة بكائن الأمر اسم الإجراء 
المخزّن .GetAuthorBooks‏ 
- ضع في الخاصية 6م/0011121015© الخاصة بكائن الأمر القيمة 
.StoredProcedure‏ 
- لا ثجر أية تعديلات على المعامل 1101 ©) الذي أضفناه إلى مجموعة 
معاملات كائن الامر. 
هذا فقط هو كل المطلوب» وسيعمل البرنامج بشكل سليم» وسيعطي نفس النتائج 
التي كان يعطيها سابقاء مع اختلاف واحد: أنه يستخدم الإجراء المخزن بدلا من 
جملة [500. 
والمشروع Auth 0o۲8 00)s R212‏ يحتوي بالفعل على هذه التعديلات. 
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موصل البيانات 102124201210161 


موصل البيانات هو مجرد حلقة وصل بين كائن الاتصال Connection Object‏ 
ومجموعة البيانات 1021256©1» ومهمته هي إيصال البيانات من الخادم إلى مجموعة 
البيانات أو العكس. 

ويتكون موصل البيانات في الحقيقة من أربعة كائنات أوامر 
»€0mmand Objects‏ تحتوي على جمل ,501 اللازمة لتحديد البيانات من 
الخادم »SE1 ٤٥1‏ وتحديثها 0۲5۸1۴ وإدراج سجلات جديدة INSERT‏ 
وحذف سجلات موجودة 08181۴ وبهذا يتيح لمجموعة البيانات حرية التعامل 
مع قاعدة البيانات في كلا الاتجاهين (الاستقبال والإرسال)؛: على عكس قارئ 
البيانات ل2٥‏ 48اه( الذي يقرأ البيانات فقط. 

في الحقيقة» فإن موصل البيانات يستخدم قارئ البيانات 12061 و4( داخليا 
لتنفيذ أمر التحديد.. لكن هذا مجرد جزء من قدرات موصل البيانات» فهو يستطيع 
إرسال التغييرات من مجموعة البيانات إلى قاعدة البيانات» كما يتيح لك عمل خراط 
للجداول Mapping‏ 16 وذلك بإعادة تسمية الجداول والأعمدة بأمتتفاء خاصة 
بك» وربطها بالأسماء الحقيقية فى قاعدة البيانات» وهو ما سنتعرف عليه بالتفصيل 
في نهاية هذا الفصل. 1 

دعنا إذن نتعرف على الواجهات والفئات التي تصنع موصل البيانات. 


1١ 


05 


تس و | الييانات IDataAdapter Interface‏ 


تقدم هذه الواجهة العناصر الأساسية لموصل البيانات» وهي تمتلك الخصائص 
التالية: 


7 فع خرائط الجداول :TableMappings‏ 
تعيد كائنا يمثل المجمو عة 1105ء155000116مم118161/13» يحتوي على 
خرائط الجداول التى يستخدمها موصل البيانات لربط الجداول من مجموعة 
البيانات بالجداول الأصلية في قاعدة البيانات.. وسنتعرف على هذا الموضوع 
RO‏ 


= التصرف عند غياب الخريطة :MissingMappingAction‏ 
تحدد ماذا سيحدث في حالة عدم وجود خريطة لبعض الجداول في مجموعة 
البيانات» وهي تأخذ إحدى قيم المرقم MissingMappingActi0n‏ التي 
سنتتعرف عليها لاحقا. 
والقيمة الافتراضية لهذه الخاصية هي «اع2255]1010» مما يعني أن مجموعة 
البيانات تستخدم نفس أسماء جداول قاعدة البيانات» ولا حاجة إلى وجود 
خريطة للجداول في هذه الحالة. 


وخ التصرف عند غياب المخطط :MissingSchema۸Action‏ 
تحدد ماذا سيحدث في حالة عدم وجود بعض الجداول أو الأعمدة في مجموعة 
البيانات» وهي تأخذ إحدى قيم المرقم )ع4 ة7تعطء 5ع م7155 التي 
والقيمة الافتراضية لهذه الخاصية هي 410» مما يعني أن الجدول الناقص أو 
العمود الناقص سيضداف إلى مجموعة البيانات تلقائيا عند ملتها بالبياناث: 


كما تمتلك هذه الواجهة الوسائل التالية: 

> ملء 111 
أرسل إلى هذه الوسيلة كائن مجموعة البيانات 1238564 التي تريد ملأها 
بالجداول والسجلات الناتجة من تنفيذ أمر التحديد 5111201 الخاص 
بموصل البيانات.. وإذا كانت مجموعة البيانات تحتوي على السجلات فعلاء 
فسيحدث أحد الاحتمالين التاليين: 


YY 


-١‏ إذا كان هناك مفتاح أساسي رم 8108197 أو قيد تفرد 
Constraint‏ 010116[] لسجلات مجموعة البيانات» فسيتم إنعاشها من 
جديد بأحدث قيم موجودة في قاعدة البيانات. 

؟د. إذا لم يكن هناك ما يميز :كل سجل ويمقع تكراره» فستضناف التدجلاتك 
إلى مجموعة البيانات مرة أخرىء مما يجعلها مكررة! 


وتعيد هذه الوسيلة عدد السجلات التي تمت إضافتها أو تحديثها. 
لاحظ أنك لا تحتاج إلى فتح الاتصال مع قاعدة البيانات أولاء فهذه الوسيلة 
تقوم بفتحه إن كان مغلقا ثم تعيد إغلاقه.. أما لو كان الاتصال مفتوحا قبل 


ويسمى كل جدول يضاف إلى مجموعة البيانات تبعا لخريطة الجدول »121 
Mapping‏ إن وجدت.. فإن لم توجد هذه الخريطة. تستخدم قواعد التسمية 


التالية: 
-١‏ إذا كان أمر التحديد يعيد سجلات جدول واحد فقطء فإنها تضاف في 


3 


3 


جدول يسمى ع[طھا. 

إذا كان أمر التحديد ينفذ أكثر من استعلام ويعيد سجلات أكثر من جدول؛» 
فإن كل نتيجة منها توضع في جدول مستقل» ويتم تسمية هذه الجداول 
بالترتيب 18616 و 186161 و 1736162... وهكذا.. لاحظ أن حدوث أي 
خطأ في أي استعلام» سيمنع تنفيذ الاستعلامات التالية له ولن توضع باقي 
النتائج في مجموعة البيانات. 

يمكنك استخدام أكثر من موصل بيانات لملء نفس مجموعة البيانات 
بالجداول.. في هذه الحالة سيضيف موصل البيانات الأول جدولا اسمه 
11» وسيحاول موصل البيانات الثاني أن يضيف جدولا اسمه 18116 
إضافته» لكن لن يحدث خطأ في البرنامج!.. هذا يوضح لك ضرورة 
استخدام خريطة الجدول لتسمية كل من الجدولين باسمين مختلفين لحل 
هذه المشكلة. 

يسمى كل عمود في مجموعة البيانات» بنفس اسمه في الجدول الأصلي 
فى قاعدة البيانات. ١ ٠‏ 1 
إذا كانت النتيجة تحتوي على أكثر من عمود بنفس الاسم 
(بسبب استخدام استعلام يجمعها من أكثر من جدول من قاعدة البيانات) 
فإنها توضع في الجدول بعد إضافة الأرقام (۱» ؟» ” ... ) إلى نهاية اسم 
العمود لمنع التشابه. 

إذا كانت بعض الأعمدة بدون أسماء (لأنها ناتجة عن دوال تجميع مثلا) 
فإنها تعطى الأسماء الافتراضية Column1‏ و Column2‏ 
و 3قتطمتنا[ه)... وهكذا. 


YY 


ويجب عليك ألا تضيف إلى مجموعة البيانات جداول أو أعمدة خاصة بك 
وتسميها بهذه الأسماء الافتراضيةء كي لا يحدث أي تعارض أو خطأ بسببها. 
وستجد مثالا على استخدام الوسيلة 171111 في المشروع 
01155 .1011017167 . في هذا المشروع نستتخدم موصل 
بيانات اسمه 1028411015 لتحميل سجلات المؤلفين من قاعدة البيانات» كما 
نستخدم موصل بيانات اسمه 1248130015 لتحميل سجلات الكتب من قاعدة 
البيانات.. ولملء مجموعة بيانات اسمها ء5 بسجلات المؤلفين والكتب» 
نستخدم الكود التالي في حدث تحميل النموذج 1"'017201_1020: 
DAAuthors.Fill(Ds)‏ 
DABooks.Fill(Ds)‏ 


ملء المخطط وَدررع را 1"1115: 
تملأ مجموعة البيانات بمخطط البيانات ورروعاء5.. هذا معناه أن الجداول 
الناتجة عن الاستعلام وتفاصيل أعمدتها ستضاف إلى مجموعة البيانات» لكن 
دون إضافة أي سجلات إليها.. بتعبير آخر: سيتم ملء مجموعة البيانات 
بجداول فارغة. 
وتستقبل هذه الوسيلة معاملين: 
- كائن مجموعة البيانات 17342564 الذي سيتم ملؤه بالمخطط. 
- إحدى قيم المرقم «SchemaType‏ تحدد ماذا سيحدث لو كان موصل 
البيانات يحتوي مسبقا على خرائط للجداول والأعمدة وع مام م13 
وهذه القيم هي: 


© | تجاهل خرائط الجداول وخرائط الأعمدة» وملء 
مجموعة البيانات بنفس أسماء الجداول والأعمدة 
الأصلية الموجودة في المخطط 2ع !اع5. 
064 | استخدام خرائط الجداول وخرائط الأعمدة» وملء 
مجموعة البيانات بالأسماء الموجودة فى هذه الخرائط 
يذلا من أسماء الجداول والأعمدة الأضلية. 
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ويتضمن المخطط الذي يتم ملء مجموعة البيانات به التفاصيل التالية: 

- اسم الجدول» وأسماء الأعمدة. 

3 خصائص کل عمود» مثل* 
أ. السماح بتركه فارغا .AllowDBNul!‏ 
ب. هل هو متفرد 1011طلا. 
ج. هل هو للقراءة فقط 15206)(1:7]. 
د. هل يزيد تلقائيا 1101201617©11.. لكن عليك أنت تحديد معدل 

الزيادة وبداية العداد» فهما لا يضافان تلقائيا. 

ه. أقصى طول للبيانات في العمود )ع 6.آ:7/13. 


- إذا كان المفتاح الأساسي رع 21103187 موجودا ضمن أعمدة 
النتيجة» يتم استخدامه كمفتاح أساسي للجدول في مجموعة البيانات.. 
وإذا لم يوجد مفتاح أساسي وكان هناك حقل متفرد القيمة عناو1ملآء 
يتم استخدامه كمفتاح أساسي للجدول في مجموعة البيانات» بشرط ألا 
يكون مسموحا بتركه فار غا (»219ه87 = 41101:126[1111).. أما إذا 
كان الحقل المتفرد يقبل القيمة ,آ[,711[1» فلن يستخدم كمفتاح أساسيء 
وستكتفي هذه الوسيلة بإضافة قيد التفرد UniqueConstraint‏ 
الخاص بهذا العمود إلى مجموعة القيود ConstrainsCollection‏ 
الخاصة بالجدول. 

- أي قيود أخرى غير المفتاح الأساسي وقيد التفرد لا تضاف إلى 
الجدول» وعليك إضافتها بنفسك! 


وتعيد هذه الوسيلة مصفوفة جداول :1123 1(31318616» تحتوي على 
كائكلت الكداول ال تمك اة ميخططاتها الى جمجموعة اليبانا 

ويمكنك بعد استخدام هذه الوسيلة» استخدام الوسيلة ۴11 لملء الجداول 
بالبيانات.. لكن كما ذكرنا سابقاء فإن استدعاء الوسيلة 17111 بمفردها يضيف 
مخططات الجداول والسجلات معا إلى مجموعة البيانات» مما يغني في معظم 
الحالات عن استدعاء الوسيلة ورررعطء 11115 أولا. 


إذن.. فما فائدة هذه الوسيلة؟ 

تفيدك هذه الوسيلة إذا أردت عرض الجداول فارغة للمستخدم ليدخل بيانات 
جديدة دون أن يعبث بالبيانات القديمة.. هذا هو ما فعلناه في المشروع 
5 حيث سيعرض جدول البيانات أعمدة جدول المؤلفين» لكنه 
لن يعرض بيانات أي مؤلفين» وبهذا يستطيع المستخدمن إدخال مؤلفين جددا 
وحفظهم في قاعدة البيانات» دون أن يغير بيانات المؤلفين السابقين. 
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تفيدك أيضا إذا أردت إنشاء المفتاح الأساسي في جدول مجموعة البيانات» 
فاستخدام الوسيلة [111 يمفرذها لا ينشئ المفناح الأساسي قى الجدول الذئ 
تضيفه إلى مجموعة البيانات» وهذا قد يسبب لك مشاكل فى بعض الحالات 
التي تحتاج فيها إلى المفتاح الأساسي» كما يحدث عند استخدام الوسيلة 
6 لدمج السجلات» أو عند البحث عن سجل بدلالة مفتاحه 


معرفة معاملات الملعء :GetFilIParameters‏ 

تعيد مصفوفة معاملات ر۸۲۲ :1ع]11034822121161: تحتوي على المعاملات 
التي استخدمها كائن الأمر عند تنفيذ أمر التحديد 9818٣1‏ الخاص بموصل 
البيانات. 


تحديث ع01216م11: 

أرسل إلى هذه الوسيلة كائن مجموعة البيانات 17342561 التي تريد نقل 
التغييرات التي حدثت على سجلاتها إلى قاعدة البيانات.. وتعيد هذه الوسيلة 
عدد السجللات التي نجح تحديثها في قاعدة البيانات. 

وتستخدم هذه الوسيلة أوامر الإضافة والحذف والتحديث الخاصة بموصل 
البيانات» لنقل التغييرات من مجموعة البيانات إلى قاعدة البيانات» تبعا للتغيير 
الذي حدث لكل سجل.. ويحدث خطأ في البرنامج» إذا لم يوفر موصل البيانات 
الأمر المطلوب من هذه الأوامر. 

لاحظ أن هذه الوسيلة ذكيةء فهي تمر عبر كل سجل في مجموعة البيانات» 
وترى إن كان هناك أي تغيير قد حدث لهذا السجلء ومن ثم تستخدم الأمر 
المناسب لإرسال هذا التغيير إلى مجموعة البيانات.. أما السجلات التي لم 
يحدث بها أي تغييرء فيتم تجاهلها. . وبهذا لا تضيع هذه لوسيلة أي وقت في 
محاولة حفظ سجلات لم يحدث فيها تغيير.. لذا فأنت لا تحتاج إلى القيام بأية 
خطوات خاصة لتحسين وظيفة هذه الوسيلة. 

لكن» لو كانت مجموعة البيانات تحتوي على أكثر من جدولء فأيها يا ترى 


يحدد هذا موصل البيانات الذي تستخدمه.. مثلا: لو استخدمت موصل بيانات 
لملء مجموعة البيانات بجدول المؤلفين: فان الوسيلة Update‏ الخاصة به 
ستتعامل مع سجلات جدول المؤلفين.. ولو استخدمت موصل بيانات لملء 
مجموعة البيانات بجدول الكتب» فإن الوسيلة مج لمل الخاصة به ستتعامل 
مع سجلات جدول الكتب.. لهذا تحتاج الجملتين التاليتين لحفظ التغييرات: 
DaAuthors.Update(Ds)‏ 
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DaBooks.Update(Ds) 


لاحظ أن هذا الكود صحيح ولكنه قد يسببب مشاكل في بعض الحالات» 
والأفضل أن تحاول تحديث الجدول الفرعي قبل الجدول الرئيسي» فلو كنت 
حذفت مؤلفا وكتبه» فإن محاولة تحديث جدول المؤلفين أولا ستحاول حذف 
سجل هذا المؤلف» وهذا سيسبب خطأ إذا كنت فرضت قيد المفتاح الفرعي 
Key Constraint‏ معزاءع801: لأن كتب هذا المؤلف ستشير إلى مؤلف غير 
موجود.. بينما لو عكست العملية» وحدثت جدول الكتب أولاء فسيتم حذف 
كتب المؤلف بلا مشاكل» ومن ثم يتم حذف المؤلف نفسه عند تحديث جدول 
المؤلفين.. لهذا عليك استخدام الكود التالي في عملية التحديث: 
DaBooks.Update(Ds)‏ 
DaAuthors.Update(Ds)‏ 


وهذا هو الكود الذي استخدمناه في الزر "حفظ في قاعدة البيانات" في 
المشروع .DataSetSample‏ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 
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2-8 واجهة موصل بيانات قاعدة البيانات 
IDbDataAdapter Interface‏ 


هذه الواجهة ترث الواجهة إهامهل۸هاه0]» وهي تمد موصل البيانات بالأوامر 
اللازمة للتعامل مع قاعدة البيانات. 
وإضافة إلى ما ترثه من الواجهة الأم» تمتلك هذه الواجهة الخصائص التالية: 


"و أمر التحديد :SelectC€om mand‏ 
هذه الخاصية من نوع الواجهة 11(5000111310» وهي تستقبل كائن الأمر 
الذي يحتوي على جملة التحديد 9818٣1‏ التي سيستخدمها موصل البيانات 
للحصول على السجلات من قاعدة البيانات عند استدعائك للوسيلة 17811 أو 
8 و.ر.ويمكن أن يحتوي أمر التحديد على مجموعة من الأوامر 
91 طءtه8›‏ وفي هذه الحالة يضيف موصل البيانات أكثر من جدول إلى 


3 أمر الإدراج :InsertCommand‏ 
هذه الخاصية من نوع الواجهة 11(5000111210» وهي تستقبل كائن الأمر 
الذي يحتوي على جملة الإدراج NSR ١‏ التي يستخدمها موصل البيانات 
عند استدعاء الوسيلة مول مء لإضافة السجلات الجديدة في مجموعة 
البيانات إلى قاعدة البيانات. 
هذا المشروع يستخدم استعلام الإدراج التالي: 
INSERT INTO Authors‏ 
(Author, CountryID, Phone, About)‏ 
VALUES (@Author, @CountryID, (@Phone, (@About)‏ 
ويريك المشروع 00/114015 كيف يمكن تعريف أمر الإدراج 
ومعاملاته» ووضعه في الخاصية 1256110011721201» واستدعاء الوسيلة 
مل لاستخدامه في حفظ السجلات الجديدة من مجموعة البيانات إلى 
قاعدة البيانات.. لاحظ أن معاملات أمر الإدراج مربوطة بمجموعة البيانات» 
لأخذ قيمها من أعمدتها مباشرة.. لقد عرفنا من قبل أن كائن المعامل 
Parameter Object‏ يملك الخاصية 5011000011010 التي نضع فيها اسم 
العمود الذي سنقرأ القيمة منه من مجموعة البيانات.. وستجد أننا أرسلنا القيمة 
إلى هذه الخاصية من خلال المعامل الرابع لحدث الإنشاء ]7 عند تعريف 
كل معامل» كما هو موضح في الكود التالي: 
InsertCmd.Parameters.AddRange(New 5112212122211) ( {‏ 
New SqlIParameter("@Author'"",‏ 
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SqlDbType.NVarChar, 0, "Author"), 
New SqIParameter('"@CountryID"', 
SqIDbType.SmallInt, 0, "CountryID"'), 
New SqIParameter('"@Phone", 
SqlDbType.VarChar, 0, "Phone"'), 
New SqIParameter("@About"", 
SqIDbType.NVarChar, 0, "About")}) 
لهذا لا نحتاج إلى كتابة أي كود لقراءة القيم من مجموعة البيانات» فعند‎ 
استدعاء الوسيلة ع1700126» فإنها تمر عبر كل صف من صفوف مجموعة‎ 
البيانات» وتأخذ قيم أعمدته وتمررها إلى معاملات أمر الإدراج» وتنفذ أمر‎ 
الإدراج.‎ 


ملحوظة: 
لإنعاش السجل المعروض في مجموعة البيانات» يمكنك استخدام جملة 
107 بعد استعلام الإدراج أو التحديث الخاص بقواعد بيانات سيكويل 
سيرفرء وذلك بوضع فاصلة منقوطة ; بين الأمرين.. مثلا: 
INSERT INTO Authors‏ 
(Author, CountryID, Phone, About)‏ 
VALUES (@Author, @CountryID, (@Phone, @About);‏ 
SELECT * FROM Authors‏ 
WHERE ID = SCOPE_IDENTITY()‏ 
نيد كن حكن اكاك مثلا: الوكان السون SS‏ 
تعمل قاعدة البياناك به (لهذا لست مشكلة أن #ضيع فيه مجموعة البيانات ١‏ 
أو ٠‏ )» خوك تعطي قاعدة البداناك السجل الرقم احج في الثر قيم عند 
إضافته إليهاء لهذا تكون جملية 51111107 مفيدة لعرض الترقيم الصحيح 
للسجل في برنامجك. 
أما إذا لم تجد داعيا لإنعاش مجموعة البيانات» فلا تستخدم أمر التحديد. 
لاحظ أن الدالة /800713_17157171175 تعيد آخر معرف تم توليده في نطاق 
التنفيذ الحالي» وهو بالطبع معرف السجل الذي أضفناه للتو.. ولا ينصح باستخدام 
الدالة ٤ N111۷‏ (]@@ لأنها قد تتأثر بعوامل أخرى في قاعدة البيانات 
مثل المنبهات ‘Triggers‏ مما يجعلها تعيد معرفا غير المعرف الخاص 
بالسجل الذي أضفته. 





ونج أمر الحذف :DeleteCommand‏ 


هذه الخاصية من نوع الواجهة 11(5000111210» وهي تستقبل كائن الأمر 
الذي بكرم على حم الحذفت 1 505 التي يستخدمها مول الياتات 
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عند استدعاء الوسيلة مهلم ل» لحذف السجلات من قاعدة البيانات إذا كانت 


وخ أمر التحديث :UpdateCom mand‏ 
هذه الخاصية من نوع الواجهة 1105000171720 وهي تستقبل كائن الأمر 
الذي يحتوي على جملة التحديث [P0۸1۴‏ التي يستخدمها موصل البيانات 
عند استدعاء الوسيلة ع1100121» لنقل التغييرات من مجموعة البيانات إلى 
قاعدة البيانات. 


ملحوظة: 

إذا كانت مجموعة البيانات تحتوي على مفتاح أساسي» وكنت قد وضعت 
أمر التحديد في الخاصية 56160100177210: فلست مجبرا في هذه الحالة 
على إنشاء أوامر الحذف والإدراج والتحديث بنفسك» فموصل البيانات 
يستطيع إنتاج هذه الأوامر آليا عند استدعاء الوسيلة مهلم ل الخاصة به 
وهو يستخدم لفعل هذا فئات بناء الأوامر ersلi1 Command 8u‏ التي 
سنتعرف عليها لاحقا في هذا الفصل. 








اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 
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2 فئة موصل البيانات DataAdapter Class‏ 


هذه الفئة تمثل الواجهة عام ھل 194۸ء كما أنها ترث الفئة .Component‏ 
ولا يمكنك تعريف نسخة جديدة من هذه الفئة» لان حدث إنشائها Constructor‏ 
محمي 4ع†ءعهإ۴» لكن يمكنك أن تتعامل مع الفئات الفرعية المشتقة منها. 


وإضافة إلى ما تمثله من خصائص الواجهة «‘IDataAdapter‏ تمتلك هذه الفئة 


ال قبول التغييرات أثناء الملعء :AcceptChangesDuringFil]l‏ 
إذا جعلت قيمة هذه الخاصية 1516 (وهي القيمة الافتراضية)» فسيتم استدعاء 
الوسيلة وعع10121مععع1(312150797.82 بعد إضافة كل صف إلى مجموعة 
البيانات» وبهذا ستعتبر مجموعة البيانات أن السجل الذي تمت إضافته لم 
يحدث به أي تغيير عن السجل الموجود فى قاعدة البيانات.. أما لو جعلت قيمة 
هذه الخاضية واو فر مسو عة البياتاك أن السجل النضنافة الها هو 
سجل جديد لم يدرج بعد في قاعدة البيانات» وعند إجراء عملية التحديث 
سيخاول معوضل البيانات إضدافته إلى قاعدة الفانات كسخل جد وهو اهر 
غير مرغوب فيه بالطبع» > إلا في بعض الحالات الخاصةء كأن تقوم بتحميل 
السجلات من أحد الجداول» وتريد حفظها في جدول مؤقت في نفس قاعدة 
البياناء أو جدول آخر في قاعدة بيانات أخرى.. لاحظ أننك في هذه الحالة 

-١‏ تجعل للخاصية 800610013186510(1011181/111, لموصل البيانات 
الأول القيمة ©1815. 

؟- نستخدم الوسيلة 17111 الخاصة بموصل البيانات الأول لملء مجموعة 
البيانات بالسجلات. 

۳- تسخدم موصل بيانات آخر لتحديث الجدول الجديد باستدعاء الوسيلة 
مهلم ؛ مع استخدام أوامر التحديث والإدراج والحذف المناسبة 
للتعامل مع هذا الجدول الجديد. 

والمشروع 4:11015/(م00) يستخدم هذه الطريقة لنسخ المؤلفين من قاعدة 
بينات آكسيس وإضافتهم إلى قاعدة بيانات سيكويل سيرفر.. لاحظ أن الوسيلة 
1 لن تحتاج إلى أوامر التحديد والحذف والتحديث في حالتنا هذه» لهذا 
لن نعرفهاء ولن يحدث خطأ في البرنامج. 
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قبول التغييرات أثناء التحديث :AcceptChangesDuring Update‏ 
إذا جعلت قيمة هذه الخاصية 106 (وهي القيمة الافتراضية)» فسيتم استدعاء 
الوسيلة ومعمa‏ 1 hata Row .Accep†C٣‏ بعد نقل التغييرات من كل صف في 
في مجمو عه ة البيانات إلى قاعدة البيانات» وبهذا تعتبر مجمو عه ة البيانات هذا 
الصف صفا عاديا لم يحدث به أي تغيير عن السجل الموجود في قاعدة 
البيانات. . أما لو جعلت قيمة هذه الخاصية ع1”1» فستظل مجموعة البيانات 
تعتبر هذا الصف مختلفا عن الصف الأصلي في قاعدة البيانات» وعند إجراء 
عملية التحديث مرة أخرى سيعاد تحديثه في قاعدة البيانات» وهو أمر غير 
مرغوب فيه في معظم الحالات» إلا إذا كنت تريد استخدام نفس مجموعة 
البيانات لتحديث أكثر من جدول.. مثلا: إذا أردت تحديث جدول المؤلفين فى 
كل من قاعدة بيانات آكسيس وقاعدة بيانات سيكويل سيرفرء فيجب عليك فعل 
مايلي: 
- وض علقم فهع88ة7 في الخاص ية 
Accept ChangesDuringU pdate‏ لموصل بیانات آکسیس 
واستدعاء الوسيلة مهلم . 
- وضع القيم ةة عںآ] في الخاص ية 
Accept changesDuringUpdate‏ لموصل بیانات سيكويل سيرفر 
واستدعاء الوسيلة مهل م.. هذا سيجعل مجموعة البيانات تقبل 
التغييرات» وتعتبر أن كل سجلاتها مطابقة للسجلات الاصليةء فقد 
استخدمنا هذه التغييرات فعلا ولم نعد نحتاجها. 
والمشروع 17013611 يريك هذه الطريقة عملياء فهو يحمل سجلات 
المؤلفين من قاعدة بيانات سيكويل سيرفرء ويملا بها مجموعة البيانات» 
ويعرضها للمستخدم في جدول» حيث يستطيع المستخدم إجراء التغيرات التي 
بريذها على اقات المؤلفين: أو کف أو بخدذف يعكن ال فين وعندما 
يضغط زر التحديث»› SEE E‏ التغييرات في قاعدتي آکسیس وسيكويل 
سيرفر معاء وبهذا ذ نضمن أن يظلا متزامنتين دائما. 
لاحظ أننا في هذا المشروع استخدمنا المعالج السحري 7712360 لإنتاج 
موصل البيانات وأوامره» لهذا لن تجد الكثير من الكود في المشروع.. 
وسنتعرف على هذا المعالج بعد قليل.. ومن المهم أن تلاحظ أن أمر التحديث 
117 يتعرف على السجل المراد تحديثه فى قاعدة البيانات من خلال 
مفتاحه الأساسي (الحقل (11 في مثالنا هذا) وقيمه الأصلية كما شرحنا سابقا.. 
لهذا لو يكن جدول المؤلفين في قاعدة آكسيس يحتوي على بعض المؤلفين 
الموجودين في قاعدة بيانات سيكويل سيرفر فلن يحدث خطأء لكن لن يتم 
تحديث هؤلاء المؤلفين لأنهم غير موجودين أصلاء ولن تتم إضافتهم أيضا.. 
هذه المشكلة لن تحدث لو أضفت مؤلفين جددا إلى جدول العرضء ففي هذه 


NYY 


الحالة سيتم حفظهم في قاعدتي البيانات بشكل صحيح.. لهذا لو أردت أن 
تضمن أن يعمل هذا البرنامج بصورة دقيقة» فيجب أن تجعل جدول المؤلفين 
في كلتا القاعدتين متمائلين منذ البدايةء لبحافظ عليهما البرنامج هكذا 
باستمرار. 


وع استمرار التحديث عند الخطأ :ContinueUpdateOnError‏ 

إذا جعلت قيمة هذه الخاصية مںإ1» فلن يحدث خطأ في البرنامج إذا حدثت 
مشكلة في تحديث أحد سجلات قاعدة البيانات» وستستمر محاولة تحديث باقي 
السجلات» مع إرسال تفاصيل المشكلة إلى الخاصية 1203717101 الخاصة 
بكائن الصف 1734312013 الذي فشلت عملية تحديثه. 

والقيمة الافتراضية لهذه الخاصية هي 72156»: لهذا سيحدث خطأ في البرنامج 
لو فشل تحديث أحد السجلات» مما سينهى عملية تحديث السجلات فى الحال.. 
وأنت حر في اختيار الطريقة التي تناسبك أكثر لمعالجة مثل هذه الاخطاء.. 
والمشروع 013161111015م[1] يتيح للمستخدم اختيار الطريقة التي تناسبه من 
خلال مربع الاختيار 801 12ع06) الموضوع على النموذج.. فلو اختار 
"مواصلة التحديث رغم حدوث أخطاء"» فسنعرض له تقريرا بالأخطاء التي 
حدثت ونطلب منه إصلاحها كما توضح الصورة. 
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| Author | CountryID | Phone | About 
| صحفي وكاتب راحل | 100| عبد الوهاب مطاوع‎ 
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¥ الاستمرار في التعديث رغم حدوث أخطاء 


:حدثت هذه الأخطاء أثناء محاولة حفظ البيانات 


1- The INSERT statement conflicted with the FOREIGIYJ KEY constraint "FK_Authors_Countries", The conflict 
occurred in database "C:{BOOKS., MDF", table "dbo.Countries", column 'ID'. 
The statement has been terminated. 


2- The INSERT statement conflicted with the FOREIGIY KEY constraint " 0 _Authors_Countries". The conflict 
occurred in database "C:\{BOOKS.MDF", table "dbo. Countries", column ‘Il 
The statement has been terminated. 





لاحظ أن جدول العرض يمنع معظم الأخطاءء فهو يرفض ترك خانة فارغة 
إذا كانت لا تقبل القيمة 7[111» كما يرفض أي نص يتكون من عدد من 


YY 








أمامك إلا أن تضع في العمود (00112/11© رقما أكبر من ۲۲» لأن قيد 
المفتاح الفرعي 00125112116 ۴OREIGN KEY‏ بين جدول الدول وجدول 
المؤلفين» يمنعك من استخدام رقم دولة ليس موجودا في جدول الدول. 

أما إن اختار المستخدم إيقاف التحديث عند حدوث أخطاء؛ فسنستخدم المقطع 
Catch‏ 7 لنعرض له رسالة خطأ عند فشل تحديث أي سجل» ونحدد له 
هذا الل في دراك الور اي او ع اة 


iForml ا×اھا۔‎ 










| About 
| صحفي وكاتب داحل‎ 
كاتب ومفكر داحلا‎ 


× 5 رلا 


The INSERT statement conflicted with the 
FOREIGN KEY constraint 
"FK_Authors_Countries". The conflict occurred 
in database "C:\BOOKS.MDF", table 
"dbo.Countries", column 'ID'. 

The statement has been terminated. 


| Author | CountryID Phone 
عبد الوهاب مطاوع‎ 1 100 









لاحظ أن السجلات التالية لهذا السجل لم تحفظ حتى الآن» وعند تكرار محاولة 
الحفظ سيتم حفظهاء وقد تظهر أخطاء جديدة في أي سجل منها في تلك 
اللحظة»ء حيث يتوجب على المستخدم تصحيحها أيضا وإعادة المحاولة.... 
وهكذا.. ورغم أن هذا يبدو مملاء إلأ أنه أسهل من كتابة تقرير طويل وترك 
المستخدم يبحث عن السجلات المذكورة في هذا التقرير لتصحيحها. 

هذا هو كود زر الحفظء مع استثناء الكود الذي يجمع أخطاء السجلات في 
الحالة الأولى» لأننا سنتعرف عليه في فصل لاحق: 


< 














If ChkContinue.Checked Then 
' استمرار التحديث رغم حدوث أخطاء‎ 
DaAuthors.Continue UpdateOnError = True 
DaAuthors.Update(Ds) 
' علينا جمع الأخطاء التي حدثت وعرضها في تقرير للمستخدم‎ 
115» ' إيقاف التحديث عند حدوث أي خطأ‎ 
DaAuthors.ContinueUpdateOnError = False 
Try 
DaAuthors.Update(Ds) 
Catch ex As SqlException 
MsgBox(ex.Message) 
End Try 
End If 
لاحظ أننا لم نكتب أي كود لوضع علامة الخطأ التي تظهر في جدول العرض‎ 
بجوار السجل الذي سبب المشكلةء فهي تظهر تلقائيا بسبب وجود ربط‎ 
بین جدول العرض ومجموعة البيانات.. وسنتعرف على تقنية ربط‎ Binding 
البيانات بالتفصيل في فصل لاحق.‎ 
ولعلك تلجأ في برنامجك إلى تعريب أهم رسائل الخطأ التي تتوقع حدوثهاء‎ 
لتعرض للمستخدم العربي رسائل يستطيع فهمهاء وكذلك لمنع المستخدم من‎ 
ر فة ناء الحداول وال عة الموحهودة فقا عة البياسانة4والقى قد‎ 
يستخدمها أي قرصان لمحاولة حقن استعلامات غير مرغوبة وتخريب قاعدة‎ 
البيانات.. في المثال السابق مثلاء كل ما يهم المستخدم أن يعرفه هو:‎ 
"لا توجد دولة لها الرقم الذي أدخلته".. طبعا سيحتاج منك الأمر إلى بعض‎ 
الجهد لكتابة كود يحلل نص الرسالة ويبني النص العربي بناء على أسماء‎ 
الجداول الأعمدة الموجؤدة فيها.. لهذا فسن الأذكى :أن تفلل احتمالات الخظا‎ 
في برنامجك إلى أقصى حد.. ففي البرامج الحقيقية» ليس على المستخدم أن‎ 
يكتب أرقام الدول» بل عليك أن تعرض له قائمة منسدلة فيها أسماء الدول»‎ 
وهو يختار منها مباشرة» كما هو موضح في الصورة.. هذا لا يسهل عليه‎ 
الحياة فقط بل يمنعه من إحداث أخطاء لا لزوم لها في البرنامج.. وستجد‎ 
مثالا على هذا في المشروع 170013111150152 والذي سيتعذر عليك فيه‎ 
رؤية أي مثال على أخطاء التحديث.. في هذا المشروع أيضا تخلصنا من‎ 
رسالة الخطأ العقيم التي يعرضها جدول العرض عند ترك صف فيه أخطاءء‎ 
وعرض نا رسالة خط أ خاصة بنا باستخدام الحدث‎ 
م مما يمنع المستخدم من معرفة أسماء‎ 101: 
الجداول والأعمدة الموجودة في قاعدة البيانات.‎ 


0 
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زا خيار التحميل :FilILoadOpti0n‏ 
تحدد هذه الخاصية ماذا سيحدث للنسخة الاصلية Original Version‏ 
والنسخة الحالية 771510 Current‏ من السجل عند استخدام الوسيلة 111 


وتأخذ هذه الخاصية إحدى قيم المرقم 110 التالية: 


OverwriteChanges 


PreserveChanges 


Upsert 








تجاهل التغييرات التي حدثت سابقا للسجل؛ 
النسيفة الأصلية والفبكة الحالية للسحل. 

هذه هي القيمة الافتراضية» وهي تحافظ على 
النسخة الحالية للسجل بدون تغييرء ووضع القيم 
الأصلية فقط, 1 

الاحتفاظ بالنسخة الأصلية للسجل بدون تغيير» 
ووضع القيم القادمة من قارئ البيانات في نسخة 
السجل الخالية فق 





وخ إعادة الأنواع الخاصة بالمزود :ReturnProviderSpecific Types‏ 
إذا جعلت قيمة هذه الخاصية مuإ1»‏ فستقوم الوسيلة 17111» باستخدام أنواع 
البيانات الخاصة بكل مزود (مثل أنواع سيكويل).. والقيمة الافتراضية لهذه 
الخاصية هي ه1815 مما يجعل الوسيلة ۴11 تحول البيانات إلى أنواع 
الائات الغادية المستخدمة في إطار العمل 


كما تمتلك هذه الفئة الوسائل التالية: 


٦ 


























7# تصفير خيار التحميل :ResetFilILoad Option‏ 
تعيد قيمة الخاصية 1100م11111.03000 إلى قيمتها الافتراضية» وتجبر 
الوسيلة 10111 على مراعاة قيمة الخاصية .AcceptChangesDuringFi|1|‏ 


فت حفظ خاصسية قب ول التغي رات أشاء الملء 
:ShouldSerializeAcceptChangesDuringFill‏ 
إذا جعلت قيمة هذه الخاصية ع1٠‏ فسيتم الاحتفاظ بقيمة الخاصية 
.AcceptChangesDuringFill‏ 


> حفظ خاصية خيار التحميل :ShouldSerializeFiIILoad Option‏ 
إذا جعلت قيمة هذه الخاصية مuإ1»‏ فسيتم الاحتفاظ بقيمة الخاصية 
.FillLoadOption‏ 


وتمتلك الفئة إع)م هل۸ هه( الحدث الوحيد التالي: 


# خþطİ‏ الملء :‘FillError‏ 
ينطلق إذا حدث خطأ أثناء ملء مجموعة البيانات.. والمعامل الثاني ع لهذا 
الحدث من النو ع کئع۲ ۲۸ع ۲۲٥۲۴۷‏ ٤۴11ء‏ وله الخصائص التالية: 


ف | 1222121 تعيد كائن جدول البيانات 1231212616 الذي حدث 
الخطأ أثناء ملئه. 

ول | Err‏ | تعيد كائن الاستثناء م10)مع8:0 الذي يحتوي على 
معلومات الخطأ الذي حدث. 

بيو | sعuام۷‏ | تعيد مصفوفة كائنات :41123 e٥)‏ jط0»‏ تحتوي 
على القيم الموجودة بالصف الذي حدث به الخطأ. 

Continue |‏ | إذا جعلت قيمتها مںإ۲٠‏ فسيستمر ملء الجدول 
بالسجلات وتجاهل الخطأ.. أما إن جعلت قيمتها 
6 فسيتوقف ملء مجموعة البيانات في الحال. 
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فنئة فئة موصل بيا قاعدة البيانات DbDataAdapter Class‏ 


هذه الفئة أساسية مجردة تجب وراثتهاء وهي ترث الفئة وع1م122]2.402. 
وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخاصيتين التاليتين: 


لعا الاسم الافتراضي لجدول المصدر 112:36ع1'21عع:121211150101: 
قيمة هذا الثابت هي 18616: .وهو الاسم الافتراضي الذي يستخدم عند إضافة 
جدول إلى مجموعة البيانات. 


وخا حجم مجموعة أوامر التحديث :UpdateBatchSize‏ 
ضع في هذه الخاصية عدد السجلات التي سيقوم موصل البيانات بحفظ 
تغييراتها فى قاعدة البيانات فى المرة الواحدة.. هذا مفيد لتقيل عدد دورات 
الاتصال مع الخادم 5م151 10120 أثناء تحديث قاعدة البيانات» مما يجعل 
أداء البرنامج أفضل. . لكن عليك أن تراعي أن التعامل مع عدد كبير من 
السجلات في نفس اللحظة قد يؤدي إلى تقليل الكفاءة (استهلاك ذاكرة أكبرء 
إرسال بيانات أكثر ووقت انتظار أطول)» لهذا عليك اختيار عدد معقول من 
السجلات يحقق أفضل أذاءر 
ولا يمكنك استخدام هذه الخاصية مع أكسيس» > لأنه لا يسمح بتنفيذ أكثر من 
أمر في المرة الواحدة.. لكن يمكنك استخدامها مع سكيويل سيرفر وأوراكل. 
والجدول التالي يلخص تأثير القيم المختلفة لهذه الخاصية: 


١‏ | تحديث سجل واحد في كل مرة.. هذه هي القيمة الافتراضية. 

١ >‏ | تحديث العدد المحدد من السجلات» حيث يتم تكوين استعلام 
لتحديث كل سجل» ودمج هذه الاستعلامات معا بوضع : بينها. 

٠‏ لا توجد قيود على عدد الأوامرء وهذا معناه استخدام أكبر عدد من 
الأوامر يمكن لقاعدة البيانات التعامل معه. 

١ <‏ | سيحدث خطأ في البرنامج! 











وفي حالة استخدام أي قيمة غير الواحد لهذه الخاصيةء يجب عليك أن تضع 
في الخاصية 110084601015010 الخاصة بكائن الأمر المستخدم في 
تنفيذ عملية التحديث القيمة None‏ أو ›0utputParameters‏ وإلا حدث 
خطأ في البرنامج. 
كما أن هذه الففة تضيف عدة صيغ جديدة لكل من الوسيلتين 1711 
و 1111516118.. دعنا نتعرف على هذه الصيغ: 


1۸ 

















> ملء 17:11: 


تضيف هذه الفئة ثلاث صيغ جديدة إلى هذه الوسيلة» وهي: 

-١‏ الصيغة الأولى تستقبل جدول بيانات 123818616 لتملأه بالسجلات.. 
وقد استخدمنا هذه الصيغة في الوسيلة MyDbConnector.Get Table‏ 
في المشروع 1013515 لملء كائن جدول »1234318616 بالبيانات 
وإعانقة للستخدم,, بعد هذا كنك إضافة هذا الحذول إلى مجتوصة 
بيانات» أو عرض بياناته مباشرة في جدول عرض أو تنفيذ أي عملية 
تريدها عليه.. وستجد في نفس المشروع مثالا على استخدام الوسيلة 
11 وذلك بضغط الزر "عرض المؤلفين"» الذي يعرض نموذجا 
جديدا عليه جدول فيه بيانات المؤلفين. 

لاد الضيغة الثانية تستقيل مجفوعة الات المراة.ملقهاء وتسا يكل انت 
الجدول المضاف إلى مجموعة البيانات.. الكود التالي مثلا سبيضيف 
جدول الكتب إلى مجموعة البيانات بالاسم 1012806015: 

DaBooks.Fill(Ds, "11150015" (‏ 
MsgBox(Ds.Tables(0).TableName) "1150015‏ 
کک الصضيفقة الثالثة لها أريعة معاملات؛ هى بالترتيب: 
د رة البيانات: 1 
- رقم السجل الذي تريد القراءة بدءا منهاء علما بأن أول سجل في 
الجدول رقمه صفر. 
- أقصى عدد من السجلات تريد قراءته من الجدول.. ولن يحدث خطأ 
إذا كان الجدول يحتوي على عدد من السجلات أقل من هذا العدد. 
- نص يمثل اسم الجدول في مجموعة البيانات. 

-٤‏ الصيغة الرابعة تفيدك عندما تريد أخذ جزء من السجلات من أمر تحديد 
يعيد أكثر من جدول» وهي تستقبل ثلاثة معاملات: 
- رقم السجل الذي تريد القراءة بدءا منها. 
- أقصى عدد من السجلات تريد قراءته من كل جدول. 
- مصفوفة معاملات 23131041336 تستقبل مصفوفة جداول 

Array‏ 123318616: ليمكنك أن ترسل إليها الجداول التي تريد 


ملأها بالسجلات. 
وتعيد هذه الوسيلة عدد السجلات التي تمت إضافتها أو تحديثها في مجموعة 
البيانات. 


ملء المخطط :FiIISchema‏ 
تضيف هذه الفئة صيغتين جديدتين إلى هذه الوسيلة» وهما: 


۹ 


-١‏ الصيغة الأولى تستقبل كائن الجدول 1231812616 المراد ملؤه» وإحدى 
قيم المرقم عم5067502157 التي تعرفنا عليها سابقا. 


؟١-‏ الصيغة الثانية تستقبل مجموعة البيانات» وإحدى قيم المرقم 
© ,: واسم الجدول في مجموعة البيانات. 


وتعيد كلتا الصيغتين كائن الجدول 1734312616 الذي تم ملؤه بالسجلات. 


:DbDataAdapter والفئات التالية ترث الفئة‎ 
OdbcDataAdapter Class . 
OleDbDataAdapter Class . 
SqIDataAdapter Class . 
OracleDataAdapter Class . 


nn E 4 


وسنكتفي هنا بالتعرف على الفئة .SqIData Adapter‏ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


لا 


42 فئة موصل بيانات سيكويل SqIData Adapter Class‏ 


هذه الفئة ترث الفئة وع14م1(51(0328023» وهي تعمل كموصل بيانات مخصص 
للتعامل مع قواعد بيانات سيكويل سيرفر. 
ولحدث إنشاء هذه الفئة أربع صيغ: 
-١‏ الصيغة الأولى بدون معاملات. 
؟- والصيغة الثانية تستقبل أمر التحديد 561601007210 الذي سيستخدمه 
موصل البيانات لملء مجموعة البيانات. 
“اد والصيغة الثالثة تقل معاملين: 
- نص جملة التحديد .SELEC1۲‏ 
- كائن الاتصال 50100011601105 الذي سيستخدم في الاتصال 
قاع انافك 
لاحظ أن موصل البيانات سيقوم بإنشاء كائن أمر 220 تتتتتةه 5016 
وسيضع جملة التحديد  S8٤٣1‏ في الخاصية Command Text‏ 
الخاصة به» كما سيضع كائن الاتصال في الخاصية Connection‏ 
الخاصة به.. بعد هذا سيوضع كائن الأمر في الخاصة 
2104 الخاصة بموصل البيانات.. معنى هذا أن هذه الصيغة 
تختصر عليك الكثير من الخطوات. 
اد الصيفة ار وا ا ا و لكو الها القائن ل کن 
الاتصال Connection Sn‏ اللازم للاتصال بقاعدة البيانات» ليتم 
استخدامه في إنشاء كائن الاتصال 014۸4 81. 


وبالإضافة إلى ما ترثه من الفئة الأم من خصائص ووسائل وأحداث» تمتلك هذه 
الفئة الحدثين التاليين: 


# يتم تحديث السجل :RowUpdating‏ 
عند استدعاء الوسيلة 1701316 الخاصة بموصل البيانات» فإنها تقوم بالمرور 
عبر كل سجل في مجموعة البيانات لاستخدامه في تحديث قاعدة البيانات.. 
وينطلق هذا الحدث قبل استخدام كل سجل موجود في مجموعة البيانات في 
عملية التحديث. 
والمعامل الثاني ع لهذا الحدث من النوع «SqlRowUpdatingEventArgs‏ 
وهو فمك الخصائصن الثالية: 

Command |‏ تقرأ أو تغير كائن الأمر 7320تتده 5010 الذي 
سيستخدم في عملية التحديث. 
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500 الخطأ الذي حدث في اا الا 

(مفيدة فقط في الحدث .(RowUpdated‏ 

تعيد كائن صف البيانات 0w‏ ۸ه)ه5› الذي يتم 

التعائل هه حاليا فى مجبوعة البيانات: 

تت نوع جملة الاستعلام التي سيت تتنيذهاء وهي 

تعيد إحدى قيم المرقم عم4157معددع]5]0 التالية: 

- 561601: جملة تحديد. 

:]nse -‏ جملة إدراج. 

- 01316م17: جملة تحديث. 

- eteاDe:‏ جملة حذف. 

- 11ه83: استعلام يتكون من مجموعة أوامر. 

تقرأ أو تغير حالة كائن الأمرء وهي تأخذ إحدى قيم 

المرقم 012346512615م]] التالية: 

:0ntinu#e -‏ الاستمرار في تحديث السجل الحالي 
والسجلات التالية له. 

:Errors0ccurred -‏ تطلب من موصل البيانات 
التعامل مع عملية التحديث كأنها تسببت في 
حدوث خطأ.. في هذه الحالة سينطلق خطأ في 
البرنامج فعلا في السطر الذي استدعيت فيه 
الوسيلة 1100131 الخاصة بموصل البيانات» 
وعليك معالجة هذا الخطأ بمقطع ج[ع021 ۷٣آ‏ . 

:Skip CurrentRow -‏ تجاوز السجل الحالي 
دون استخدامه في تحديث قاعدة البيانات» مع 
استمرار تحديث باقي السجلات. 

:Skip AR emainingRows -‏ تجاوز السجل 
الحا والسهلات الثالية له قاف عدلي: 
التحديث في الحال. 

تعيد كائن خريطة الجدول «DataTableMapping‏ 

الذي يستخدم للربط بين الجدول في مجموعة 

البيانات والجدول الأصلي في قاعدة البيانات. 


۲ 























۶۶ تم تحديث السجل Row Updated‏ : 
ينطلق هذا الحدث في كل مرة ينتهي فيها موصل البيانات من استخدام أحد 
والمعامل الثاني ع لهذا الحدث من gill‏ ع «SqIRowUpdatedEventArgs‏ 
وهو يمتلك نفس خصائص الفئة Sq]R ow Updating Eve †A gs‏ التي 
تعرفنا عليها في الحدث السابق» ويزيد عليها بالعناصر التالية: 


59 به |  RecordsA fected‏ تعيد عدد السجلات التي تأثرت بعملية 
التحديث في قاعدة البيانات.. هذا العدد 
يكون صفرا إذا لم يتم العثور على 
السجلء أو حدث خطأء ويكون ١‏ إذا 
كنت تستخدم جملة S1٤٣1‏ الخاصة 
1507 الموجودة في نهاية أمر 
التحديث وأمر الإدراج تؤثر على قيمة 
هذه الخاصية» وتجعل قيمتها صفرا! 

2 بر RowCount‏ هذه الخاصية مفيدة إذا كانت للخاصية 
€pdateBatchSize‏ الخاصة بموصل 
البيانات قيمة أكبر من ١ء‏ ففي هذه الحالة 
سجل في المرة الواحدة» حيث تعيد إليك 
هذه الخاصية عدد السجلات التي تم 
التعامل معها.. لاحظ أن هذا العدد قد 
يكون مساويا لقيمة الخاصية 
UpdateBatchSize‏ أو أصغر منها 
(في حالة عدم وجود سجلات كافية في 
مجموعة البيانات). 

ا Il | CopyToRows‏ كانت للخاصية Update BatchSize‏ 
قيمة أكبر من ١ء‏ فإن الخاصية س0 ۸.م 
لا تفيدك لمعرفة السجلات التي تم حفظ 
بياناتها في قاعدة البيانات.. وبدلا منهاء 
بمكنك إرسال مفمسفرقة صرف 
Array‏ 1031310077 إلى هذه الوسيلةء 
لتوضع فيها صفوف: مجموعنة البيادات 
التي تم استخدامها في عملية التحديث› 
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مع ملاحظة أن هذه العملية مرجعية 
By Reference‏ أي أن أي تغيير في 
الصفوف الموجودة في المصفوفة 
سيظهر تأثيره في مجموعة البيانات.. 
ويجب أن تحتوي المصفوفة المرسلة 
على الأقل على عدد من الخانات يساوي 
قيمة الخاصية .e.RowCount‏ 

وتوجد صيغة أخرى لهذه الوسيلةء لها 
يي وتخ الفيلوف في المصيدرفة 


بدءا منه. 














ملحوظة: 

لعلك تتساءل لماذا لا يمتلك معامل الحدث عمناولم ل سه۸ الوسيلة 
75 ا االسبب في هذا أن الحدث ع012110م101717 ينطلق 
دائما قبل تحديث كل صف على حدة» حتى لو كان موصل البيانات 
سيستخدم مجموعة أوامر ,501 83:5 لتحديث مجموعة صفوف دفعة 
واحدة.. هذا منطقي» لأن موصل البيانات يقرأ سجلا تلو سجل من 
مجموعة البيانات (ويطلق الحدث ع 120177110022 لكل سجل)» وبعد هذا 
يكوّن موصل البيانات مجموعة أوامر لتحديث السجلات التي قرأهاء 
ويرسل هذه الأوامر المجمعة إلى قاعدة البيانات» ثم يطلق الحدث 
4 بعد تنفيذها. 








لاحظ أنك لو لم تكتب الإجراء المستجيب للحدث «RowUpdated‏ فإن 
الوسيلة مهلملا تطلق خطأ في البرنامج إذا حدثت مشكلة تطابق 
Concurrency 1‏ عند حفظ أحد السجلات.. أما إذا كتبت الإجراء 
المستجيب لهذا الحدث» فإن الخطأ لا يحدث» وتتاح لك الفرصة لكتابة الكود 
الذي يحل مشكلة التطابق. 

لكن.. ما هو موضوع التطابق yإc €٥cu ۲۲e‏ هذا؟ 

هذا هو موضوع الفقرة التالية. 


NYE 

















التصار تحديث البيانات: 

هناك مشكلة رئيسية ستواجهك عند التعامل مع قاعدة بيانات يستخدمها أكثر من 

موظف في نفس الوقت» وهي التضارب بين التعديرت التي يجريها أكثر من 

موظف على نفس السجل.. تخيل هذه الحالة: 

- قام مستخدم برنامجك بتحميل سجلات الكتب» وقام بتعديل سعر كتاب "عضا 
الحكيم" من © جنيهات إلى ۷ جنيهات. 
- عند محاولة برنامجك حفظ هذه التغييرات في قاعدة البيانات» كان مستخدم 

آخر قد غير عدد النسخ المتاحة المتاحة من كتاب "عصا الحكيم" من ٠٠٠٠١‏ 
ا 

السؤال الآن هو: ماذا نفعل فى هذه الحالة؟ 

لو حفظ برنامجك سجل الكتاب "عضا الحكيم" فسيعدل سعره إلى ۷ جنيهات» لكنه 

سيعيد عدد النسخ المتاحة منه إلى !٠٠٠١‏ 

أما لو أبقينا على التعديلات التي أجراها المستخدم الآخرء فهذا معناه الإبقاء على 

التعديل الذي حدث في عدد النسخ» لكن السعر سيظل © جنيهات! 

طبعا في كلتا الحالتين ستحدث مشكلة في العمل.. وعندما سيحاول المدير معاقبة 

مسئول المخازن في الحالة الأولى فسيقسم له بأغلظ الأيمان إنه غير عدد النسخ 

المتاحة» وعندما سيحاول معاقبة مسئول المبيعات في الحالة الثانية» فسيقسم له إنه 

حير عر شك وكلاهما صادق في قسمه» وأنت الذي خربت بيته! 

تسمّى هذه المشكلة باسم مشكلة التطابق جممءع1ط851+0 ..Concurrency‏ ويمكن 

علاجها بأحد الحلين التاليين: 


:Pessimistic Concurrency التطابق المتشائم‎ ١ 
استخدم هذا الحل لو كنت "متشائما" بخصوص تعارض البيانات التي يحفظها‎ 
المستخدمين» أو كان أي تعارض يمكن أن يؤدي إلى خسائر كبيرة للعمل الذي‎ 
ينظمه برنامجك» حيث إن التطابق المتشائم يمنع حدوث أي تضارب في‎ 
البيانات» وذلك بإغلاق ج[ع1.0 سجلات قاعدة البيانات قام أي مستخدم‎ 
بتحميلهاء »مما يمتع آي هتخم أختر'من تغييزها إلى أن وتم يغلق المستخدم‎ 
الأول الاتصال وتتم تم إزالة الإغلاق.. ويمكن تنفيذ هذا الحل في دوت نت‎ 
باستخدام التعاملات 173153611025: لهذا سنؤجل تطبيقه إلى الكتاب القادم إن‎ 

شاء الله. 
وعند استخدام هذا الحل» تكون جملة التحديث بسيطة للغايةء لأنك تستخدم 
المفتاح الأساسي للحقل للعثور عليه في قاعدة البيانات» ومن ثم تغير قيمه 
مباشرة» لأنك واثق أنه لم يتغير منذ أن قمت بتحميله.. هكذا مثلا ستكون جملة 
تحديث سجلات المؤلفين: 

UPDATE Authors 


Yo 


SET Author = @Author, 
CountryID = (@CountryID, 
Phone = @Phone, 
About = @About 
WHERE ID = @ID; 
لاحظ أن المعاملات الموجودة في هذا الاستعلام تأخذ قيمها من خانات السجل‎ 
الذي يتم تحديثه في مجمو عه ة البيانات.‎ 
ويعتبر التطابق المتشائم حلا حاسما للمشكلةء لأن أي مستخدم آخر سيحاول‎ 
تعديل السجلات المتنازع عليها سيحصل على رسالة خطأ تخبره بأنها مغلقة‎ 
من قبل مستخدم آخر.. وفي هذه الحالة عليك أن تجعل برنامجك ينتظر انتهاء‎ 
الإغلاق» :ومن كمنيعرض الست البدجلات التي يجاول تحديتهاهء يمرك‎ 
على التغييرات التي تمت عليهاء ومن ثم يقرر كيف يوائم بينها وبين التغييرات‎ 
التي أجراهاء ثم يعيد حفظها في قاعدة البيانات.‎ 
لکن المشكلة هي أن التطابق المتشائم سيهبط بكفاءة البرنامج إذا استمر إغلاق‎ 
كل سجل لفترات زمنية طويلة» أو إذا تم تحديث أعداد ضخمة من السجلات‎ 
على التتابع» وذلك لأن إغلاق السجلات يستهلك جزءا من وقت تشغيل وذاكرة‎ 
الخادم» كما أنه يحتاج إلى إبقاء قنوات الاتصال مفتوحة مع المستخدمين الذين‎ 
قاموا بعملية الإغلاق» مما يحرم مستخدمين اخرين من الاتصال بقاعدة‎ 
البيانات في ذلك الوقت.. لكن يظل التطابق المتشائم الحل الأفضل عند التعامل‎ 
مع قاعدة بيانات يتصل بها عدد كبير من المستخدمين في نفس اللحظة؛‎ 
ويتصار عون على تحديث نفس السجلات» لأن استخدام كثرة عمليات التراجع‎ 
عن التعاملات عاعه120116 113253085 لاستعادة القيم الأصلية قبل‎ 
التضارب» تستهلك الخادم في هذه الحالة بأكثر مما تفعل عمليات الإغلاق.‎ 


التطابق المتفائل :Optimistic Concurrency‏ 
هذا هو الحل المفضل والأسهل في تقنية '41(0.721171»: وقد سمي بهذا الاسم 
لأنه يفترض أن المستخدمين لن يحاولوا تعديل قاعدة البيانات» أثناء تعاملك مع 

بياناتها فى برنامجكء إلا فى حالات نادرة. 

لكن.ماذا يحدت لو حدث التعازطن:فخلة؟.. كيف نحل المشكلة ف هذه الحالة؟ 
في الحقيقة هناك عدة حلول متبعة» وعليك اختيار لحل الذي يناسبك منها تبعا 
لما يناسبك.. وهذه الحلول هي: 

أ. عند تحديث السجلء يتم البحث عنه في قاعدة البيانات بواسطة قيم كل 
حقوله. وليس فقط بواسطة المفتاح الأساسي.. هذه مثلا جملة الاستعلام 
الخاصة بتحديث سجلات المؤلفين: 

UPDATE Authors 


1 


SET Author = @Author, 
CountryID = @CountryID, 
Phone = @Phone, 
About = @About 
WHERE (ID = @Original ID) AND 
(Author = @Original Author) AND 
(CountryID = @Original CountryID) AND 
(@IsNull_Phone = 1) AND (Phone IS NULL) OR 
(ID = @Original ID) AND 
(Author = @Original Author) AND 
(CountryID = @Original CountryID) AND 
(Phone = @Original Phone) 
هذا الاستعلام يضمن لك أنه لو حدث أي تغيير في السجل من قبل‎ 
مستخدمين آخرينء فلن يعثر عليه برنامجكء وبالتالي لن يتم حفظ‎ 
التغييرات التي قام بها مستخدم برنامجك.‎ 
لعلك تلاحظ في هذا الاستعلام وجود معاملين للتعامل مع كل حقل..‎ 
Q@Author مثلاء يتم التعامل مع حقل المؤلفين من خلال المعاملين‎ 
فما هو الفارق بينهما؟‎ ..@0rigina1_ Author و‎ 
120385614 لكي تفهم هذا الفارق» عليك أن تعرف أن مجموعة البيانات‎ 
تحتفظ بنسختين من كل سجل يتم وضعه فيها:‎ 
:Original Version النسخة الأصلية‎ - 
وهي تحتوي على بيانات السجل الأصلي كما تم تحميلها من‎ 
قاعدة البيانات» لاستخدامها بعد ذلك فى البحث عن السجل‎ 
1 الأصلى فى قاعدة البيانات لتحديثه.‎ 
:Current Version النسخة الحالية‎ - 
وهي تحتوي على بيانات السجل بعد التغييرات التي أجراها‎ 
المستخدم عليهاء وذلك لاستخدامها في تحديث السجل الأصلي‎ 
فى قاعدة البيانات.‎ 
وكل ما يفعله استعلام التحديث السابق» هو تعريف معاملين لكل حقل؛‎ 
أحدهما يقرأ قيمته الحالية (مثل 41101 ©)) ويتم استخدامه لحفظ‎ 
التغييرات في قاعدة البيانات» والآخر يقرأ قيمتهالأصلية‎ 
(مثل :0ط)ن1ى_21مزع0011©)) ويستخدم للبحث عن السجل الأصلي في‎ 
قاعدة البيانات. . ويتم التفريق بين هذين المعاملين باستخدام الخاصية‎ 
الخاصة بكائن المعامل 1031322116161 والذي‎ Version 
يمكن إرسال قيمته من خلال المعامل التاسع لحدث الإنشاء سه...‎ 


YY 


هكذا مثلا يتم تعريف المعامل إ0طا ں۸ @.. لاحظ أننا لن نرسل قيمة 
المعامل 1510ه57ع5010» لهذا سيتم سيقرأ القيمة الحالية افتراضيا: 
Dim 21 As New SqlParameter('"@Author",‏ 
SqIDbType.NVarChar, 0, "Author")‏ 
وهكذا يتم تعريف المعامل :@Original Author‏ 
Dim P2 As New SqlParameter("@Original Author",‏ 
SqlDbType.NVarChar, 0,‏ 
ParameterDirection.Input, False, 0, 0, "Author",‏ 
DataRowVersion.Original, Nothing)‏ 
لكن.. لماذا لا يوجد شرط على الحقل ها۸ في المقطع عامط W؟‏ 
السبب في هذا أننا عرفنا هذا الحقل من النوع (×varcha۲])M۸ء‏ 
وهذا معناه أنه يتسع لنص قد يصل إلى ۲ مليار حرف» وهذا حجم 
هائل» وستكون :مقار نة هذا الحقل مضبيعة لوقت ,لکن لو كنت مصيواء 
فيمكنك تعديل الاستعلام.. لا أنصحك بفعل هذا من نافذة الخصائص» 
لأنها ستعجز عن إنشاء المعامل ]1اوطلى_021زع011©) بشكل 
صحيح» وبلا من هذا يمكنك إضافة هذا الكود في بداية حدث تحميل 
إضافة شرط إلى نهاية استعلام التحديث ' 
سيحدث خطأ لو كان هناك استعلام تحديد في نهاية استعلام التحديث ' 
DaAuthors.UpdateCommand.Command Text &=‏ 
And About = @Original About"‏ " 
تعريف معامل جديد ' 
Dim 2 As New SqlIParameter("@Original About",‏ 
SqIDbType.NVarChar, -1,‏ 
ParameterDirection.Input, False, 0, 0, "About",‏ 
DataRowVersion.Original, Nothing)‏ 
إضافة المعامل إلى مجموعة معاملات أمر التحديث ' 
DaAuthors.UpdateCommand.Parameters.Add(P)‏ 
أو يمكنك فتح ملف تصميم النموذج 0©1.16ع10111_1(51» وتعديل 
استعلام التحديث مباشرة» وإن كنت لا أنصح بهذا. 
لاحظ أن من الأفضل تغيير نوع الحقل 46016 ليكون أكثر ملاءمة 
لوظيفته.. يمكنك افتراض أن أطول نبذة لا تزيد عن 5٠٠‏ حرف مثلاء 
وتعريف هذا الحقل منن النوع (15772161121)50. 
دعنا نعد إلى استعلام التحديث السابق» فمازال هناك نوع ثالث من 
المعاملات لم نتطرق إليه.. هذا المعامل مخصص لللتعامل مع القيم 
المنعدمة ,21111 (مثل المعامل 026ط6015171111_2)).. وسبب 


ا 


احتياجنا إلى هذا المعامل» هو أن أي عملية مقارنة مع خانة منعدمة 
تعطي دائما ع12318» لهذا لو كانت خانة الهاتف فارغة في قاعدة 
البيانات» وكانت فارغة أيضا في النسخة الأصلية من السجلء فإن 
مقارنتهما ستعطي عو[ه۴»› وهذا يعني أن برنامجك لن يستطيع تحديث 
خانة الهاتف أبدا! 
لحل هذه المشكلةء نستخدم الشرط التالي: 
(@IsNull Phone = 1) AND (Phone IS NULL)‏ 
OR (ID = @Original ID)‏ 
هذا الشرط يتأكد من أن خانة الهاتف فارغة فى مجموعة البيانات» وأنها 
فارغة أيضا في قاعدة البيانات» أو أن الخانتين فيهما قيمتان متساويتان. 
ويتم تعريف المعامل 026ط1511111_2©)) بوضع القيمة 1016" في 
الخاصية 118م1111221071111137 5011166000 الخاصة بكائن المعامل» 
وهو ما يمكن فعله بإرسال القيمة ع11 إلى المعامل التاسع في إحدى 
صيغ حدث الإنشاء 7161 كالتالي: 
Dim 23 As New SqlParameter("@IsNull Phone",‏ 
SqIDbType.Int, 0, ParameterDirection.Input,‏ 
"Phone", DataRowVersion.Original,‏ ,0 ,0 
True, Nothing, E 11 9-0‏ 
لاحظ أن موصل البيانات يستخدم استعلام التحديث السابق بصورة 
افتراضية»ء لكن هذا قد يهبط بكفاءة برنامجكء إذا كان الجدول يحتوي 
على عدد كبير من السجلات» مما يعقد استعلام التحديث» ويستهلك وقتا 
ملموسا من سيكويل سيرفر للبحث عن السجل في قاعدة البيانات» لأنه 
سيقارن هنا كل الخانات» وليس من المتوقع وجود فهارس لكل أعمدة 
قاعدة البيانات. 
ب. عند تحديث السجلء يتم البحث عنه في قاعدة البيانات بواسطة مفتاحه 
الأساسي فقط (كما فعلنا في التطابق المتشائم).. ميزة هذه الطريقة أنها 
تبسط استعلام التحديث» وتجعل العثور على السجل في قاعدة البيانات 
أسرع لأن المفتاح الأساسي مفهرس ٥×4‏ لم[»› وهي ميزة هائلة في 
قواعد البيانات الضخمة.. لكن عيب هذه الطريقة هي أنها تستخدم مبدأ 
"آخر تحديث يكسب!".. حيث إنّ السجلات يتمّ حفظها إلى قاعدة 
البيانات» حثى ولو كانت هناك تعديلات قد أجراها مستخدم آخر عليها.. 
إنك تفرض سجلاتك على قاعدة البيانات رغم أنف الجميع 5 
سيخرب بيت مدير المخازن عند تعديل سعر كتاب عصا الحكيم).. لكن 
أحيانا تكون هذه الطريقة مقبولة كما في أنظمة حجز رحلات او 
لان آخر تعديل في مواعيد الحجز هو الأولى بالاعتبار. 


۹ 


ج. 


عند تحديث السجلء يتم البحث عنه في قاعدة البيانات بواسطة المفتاح 

الأساسي وطابع الوقت م2ه]1165'.. لفعل هذا عليك إضافة عمود 
من النوع م1هاءع صز إلى الجدول.. هذا العمود يتغير تلقائيا كلما تم 
تعديل السجل» وبهذا لو كان طابع الوقت الذي تحتفظ به مجموعة 
البيانات مختلفا عن طابع الوقت الموجود في قاعدة البيانات» فهذا معناه 
أن السجل قد تغير» وفى هذه الحالة لن يحفظ برنامجك التغييرات فى 
هذا السجل.. لاحظ أن المعالج السحري لموصل البيانات ينتج اوا 
تحديث تعتمد على طابع الوقت إذا وجده في استعلام التحديد» أما إذا لم 
يجده» فإنه ينتج أوامر تحديث تقارن كل الحقول كما في الطريقة أ. 


لاحظ أن الطريقتين أ و ج هما الأكثر شيوعاء لكن بهما مشكلة كبيرة» وهي أن 
برنامجك سيكتفي بعرض رسالة خطا للمستخدم تخبره بان أحد الصفوف 
يتعارض مع قاعدة البيانات» دون أن يعرف التغييرات التي حدثت في قاعدة 
البيانات» ودون أن يستطيع إعادة حفظ السجل» لأن نفس الخطأ سيستمر في 
الحدوث!! 

ولحل هذه المشكلة؛» عليك استخدام الحدث RowUpdated‏ الخاص بموصل 
البيانات بالطريقة التالية: 


إذا كانت قيمة الخاصية 0ع]1ع/010541ع16.» تساوي صفراء فهذا 
معناه أن أمر التحديث لم يؤثر على قاعدة البيانات» لأنه لم يجد السجل 
المطلوب تحديتهء إما لأن مستخدما آخر حذفه أو عدل بياناته.. هذا هو 
التعارض الذي نبحث عنه.. لاحظ أن وجود جملة 5111901 في 
نهاية أمر التحديث سيجعل الخاصية 120001058110160 تعيد الرقم 
٠‏ دائما.. لهذا إذا أردت أن تستفيد من هذه الخاصية في معرفة إن كان 
التحديث قد تم أم لاء فعليك أن تزيل جملة التحديد من نهاية أمر 
التحديث.. وسنعرف كيف نفعل هذا من خلال المعالج السحري 
لموصل البيانات بعد قليل. 

ضع نصا يدل على حدوث خطأ في الخاصية «e.Row.ROWEITOr‏ 
مثل "حدث تعارض مع السجل الأصلي لأن أحد المستخدمين قام 
بتعديله أو حذفه".. هذا سيجعل أيقونة الخطأ تظهر بجوار السجل في 
جدول العرضء وعند التحليق فوقها بالفارة سيظهر تلميح على الشاشة 
يعرض للمستخدم النص الذي كتبته في هذه الخاصية. 

إذا أردت أن يحدث خطأ في البرنامج في سطر استدعاء الوسيلة 
11 لتعالجه بطريقتك الخاصة»ء فضع في الخاصية 5186015.© 
القيمة 801015000111160.. أما إذا أردت مواصلة عملية التحديث» 


E2 


فضع فيها القيمة 41016م0© أو ..SkipCurrentRow‏ دعنا نستخدم 
القيمة الأخيرة. 
- يبدو الأمر رائعا حتى الآن» وسيلاحظ المستخدم ظهور أيقونات الخطأ 
بجوار السجلات التي فشل تحديثها.. لكن المشكلة أن المستخدم لا 
يعرف التعديل الذي أدخله المستخدمون الآخرون على السجل الأصلي 
في قاعدة البيانات.. لهذا سنلجاً إلى طريقة مبتكرة» وهي استخدام 
موصل بيانات اسمه طا 4۴۲۲۸ لتحميل السجل الأصلي مرة 
أخرى في مجموعة بيانات خاصة اسمها :1(0517» وعرضه في جدول 
عرض آخر اسمه 1(111015» ليقارن المستخدم بين البيانات التي 
يريد حفظهاء والبيانات التي حفظها مستخدم آخر» ويتخذ قراره بناء 
على هذاء كما هو موضح في الصورة. 
لاحظ أن السجلات التي حذفها مستخدم آخر من قاعدة البيانات لن 
تظهر في جدول السجلات المعدلة.. من السهل أن يفهم المستخدم أن 
السجل قد حذف إذا لم يجده» لكننا أيضا نستطيع التسهيل عليه» بتغيير 
رسالة الخطأ إذا كان استعلام التحديث لا يعيد أية سجلات» وذلك 
كالتالي: 
If DaErrAuthor.Fill(DsErr, "Authors'") > 0 Then‏ 
»ع "حدث تعارض مع السجل الأصلي" = e.Row.ROWE!IOr‏ 
" لأن أحد المستخدمين قام بتعديله أو حذفه " 
Else‏ 
& "هذا السجل حذفه مستخدم" = e.Row.RoWError‏ 
" آخر من قاعدة البيانات " 
End If‏ 


EN 


تافر هضرف معاصر 
ركاتي سردي 


تقب ههرق ماهر 


كاتب في ضغال ال 


شاعر هصرف قعاصر 





- بقيت أمامنا خطوة أخيرة» وهي: كيف نسمح للمستخدم بتعديل السجل 
المعدل أن إغاذة السجل المحذوقكه ان قرو هدا آنا أرى أن أفضيل 
حل» هو عرض قائمة موضعية حينما يضغط الصف الذي به خطأ في 
الجدول العلوي» ومن هذه القائمة يختار ما يناسبه مما يلي: 


أ 


الأمر "أريد حفظ تعديلاتي": 

سنستخدم هذا الأمر عندما يغير مستخدم آخر السجل» وهو ينسخ 
القيم الأصلية من سجل قاعدة البيانات المعدل ويجعلها القيم 
الأصلية للسجل الخاص بالمستخدم» وهذا حتى ينجح استعلام 
التحديث في العثور على السجل الأصلي في قاعدة البيانات» ومن 
ثم لى,طبغط المستخدم رر الحفظ يتم حفظ تعديلاته.. والمستخدم 
هو المسئول عن نقل أية قيمة يدويا من السجل الأصلي المعروض 
في جدول العرض السفلي إلى السجل الخاص به قبل ضغط زر 
الحفظ.. والسجل الذي تنجح محاولة حفظه مرة أخرى» علينا أن 
نزيل سجل الخطأ المناظر له من جدول العرض السفلي. 

لاحظ أنك في البرامج العملية قد تحتاج إلى مراعاة أولويات 
المستخدمين في إجراء التغيير.. مثلا: لو كان المدير هو من قام 
بتعديل السجلء فسيستشيط غضبا لو قام أحد الموظفين بإلغاء 
تعديله!.. لهذا قد تحتاج إلى إضافة حقل اسمه (79611] إلى 
الجدول» ليربطه بجدول المستخدمين و17هع119» بحيث تضع رقم 
البرنامج» لا تسمح للمستخدم باتخاذ قرار حفظ تعديلاته إلا إذا كان 


a 


المستخدم الآخر أقل أولوية منه أو على الأقل له نفس الأولوية في 
إجراء التعديلات.. ويمكنك معرفة أولويات المستخدمين من 
الجدول إمولاء الذي لا بد أن يحتوي على عمود يوضح وظيفة 
المستخدم» أو عمود يوضح ترتيبه في السلم الوظيفي أو مدى 
صلاحياته. 


ب. إلغاء تعديلاتي: 
سنستخدم هذا الأمر عندما يغير مستخدم آخر السجل.. هذا الأمر 
سنفعله هو نقل السجل المعدل إلى مجموعة البيانات ليحل محل 
على التعديل القادم من قاعدة البيانات. 
ج. الأمر "أريد إعادة إدراج السجل المحذوف": 

سنستخدم هذا الأمر إذا حذف مستخدم آخر السجل من قاعدة 
البيانات.. وكل ما يفعله هذا الأمرء هو تغيير حالة السجل الحالى 
إلى 0060 » ليعتبره أمر التحديث سجلا جديدا ويضيفه إلى قاعدة 
البيانات 


د. الأمر "إزالة السجل المحذوف": 
سنستخدم هذا الأمر إذا حذف مستخدم آخر السجل من قاعدة 
البيانات.. وكل ما يفعله هذا الأمر» هو حذف السجل الخاص 
بالمستخدم من مجموعة البيانات. 


وة الكو الات اليد ی د كتيل هده افکان ف 
المشروع ..ptimistic Concurrency‏ وتوجد نسخة أخرى منه في 
المشروع ›0ptimistic Concurrency W ith TimeStamp‏ نستخدم فيها 
طابع الوقت» حيث عرفنا عمودا اسمه 1207717615102 في جدول المؤلفين 
نوعه مإهاوص1إ.. لاحظ أن عرض طابع الوقت في جدول العرض 
Datagrid View‏ يسبب أخطاء لأنه يحاول رسم طابع الوقت باعتباره 
صورةا!.. ولحل المشكلة» عليك إخفاء عمود طابع الوقت» فلا يوجد مبرر 
أصلا لعرضه للمستخدم!.. لفعل هذا استخدمنا الجملة التالية: 

DgAuthors.Columns("'RowVersion'").Visible = False 


EE 


لاحظ أن هناك مشكلة ستواجهنا في هذا البرنامج» بسبب عدم استخدامنا جملة 
تحديد 561601 بعد جملة التحديث مهلم ل» وذلك لأن طابع الوقت يتغير في 
قاعدة البيانات باستمرار بعد كل عملية تحديث» ولو لم ننعش مجموعة البيانات 
بالقيم الجديدة له» فستحدث مشكلة تطابق بلا داع.. ولحل هذه المشكلة 
استخدمنا موصل بيانات اسمه م1(3:131126518121» مهمته الحصول على السجل 
الذي تم تحديثه» ووضعه في مجموعة البيانات لإنعاشها.. لهذا يستخدم أمر 
التحديد الخاصن يهذا الموضيل جملة التحدته الال 
Select * From Authors‏ 
Where ID = @ID‏ 
وأنسب مكان لاستخدام هذا الموصلء هو الحدث إءهل مل س0 8؛ لأنه ينطلق 
مباشرة بعد تحديث الصف لهذا يمكننا أن نقرأ الصف مرة أخرى بعد أن 
غيرت قاعدة البيانات طابع الوقت الخاص به.. لهذا طورنا جملة الشرط التي 
نستخدمها في هذا الحدث» بإضافة المقطع 10196 كالتالي: 
If e.RecordsAffected = 0 Then‏ 
الكود المناسب لحل مشكلة التطابق ' 
Elself e.StatementT'ype <> StatementType.Delete Then‏ 
TimestampCmd.Parameters(0).Value = e.Row("ID")‏ 
DaTimestamp.Fill(Ds, "Authors'"")‏ 
End If‏ 


مخ ع النراذات كما حف مق فاع انات و ا 5 مشكلة ` 


غير هذا لن تجد أي اختلاف في كود كد aS e‏ 
2016127 فالفروق كلها تنحصر في صيغة استعلامات 
التحديث» التي تزيد كفاءة برنامجك بسيب استخدامها لطابع الوقت» بديلا عن 


مقارنة كل القيم الموجودة في خانات الصف. 


٤ 


كا المعالج السحري لإعداد موصل البيانات 


Data Adapter Configuration Wizard 


استخدم هذا المعالج لتسهيل ضبط وظيفة وخصائص موصل البيانات.. ويمكنك 
تشغيل هذا المعالج باتباع أي مما يلي: 
النقر مرتين على أيقونة موصل البيانات إم†مaل S4124‏ في صندوق 
الأدوات عر1001860. 
- سحب أيقونة موصل البيانات من صندوق الأدوات وإلقائها على النموذج. 
- ضغط موصل البيانات بعد إضافته إلى صينية مكونات النموذج 
Component Tray‏ بزر الفأرة الأيمن» ومن القائمة الموضعيّة ضغط 
الآمر .Configure Data Adapter‏ 
ويبدأ هذا المعالج بنافذة تطلب منك اختيار قاعدة البيانات التي تريد الاتصال بها: 


Data Adapter Configuration ¥izard لعا‎ 


Choose Your Data Connection 


The data adapter will execute queries using this connection to load and update data. 


which data connection should the data adapter use? 
[Books.mdf 41 | New Connection... | 


which is ae 






Connection string‏ حا 





Data Source=, (SQLEXPRESS; AttachDbFilenarne=E:\___Batabase_YB\Samples\Books.mdf;Integrated 
Security=Truej Connect Timeout=30jUser Instance=True 


Next > | Finish | Cancel | 








في هذه النافذة» يمكنك استخدام القائمة المنسدلة لاختيار اسم إحدى قواعد بيانات 
سيكويل سيرفر التي أضفت اتصالا بها من قبل في متصفح الخوادم 
.Server Explorer‏ 

ولو أردت إنشاء اتصال جديد بقاعدة بيانات أخرى» فاضغط الزن 
New Connection‏ لتظهر لك نافذة إضافة اتصال 00012166110 ۸44 التي 
تعرفنا عليها من قبل في متصفح الخوادم. 


to 


ولو ضغطت العلامة + المجاورة للجملة 5108 م30اءعمطه0) في الجزء السفلي 
من النافذة» فسيتم عرض مربع نص قابل للقراءة فقطء به نص الاتصال بقاعدة 
البيانات التي اخترتها.. ويمكنك نسخ هذا النص لاستخدامه في أي موضع آخر في 
البرنامج لو أردت. 

جرب على سبيل المثال اختيار قاعدة بيانات الكتب 5.13101ع8001: واضغط الزر 
.Next‏ 

في النافذة التالية يمكنك اختيار نوع الاستعلام الذي ستستخدمه لإحضار البيانات من 
قاعدة البيانات: 


Data Adapter Configuration ¥izard ا2‎ 


Choose a Command Type 


The data adapter uses SQL statements or stored procedures, 


How should the data adapter access the database? 
f Use SQL statements 


Specify a SELECT statement to load data, and the wizard will generate the INSERT, UPDATE, and DELETE 
statements to save data changes. 


(` Create new stored procedures 


Specify a SELECT statement, and the wizard will generate new stored procedures to select, insert, update, 
and delete records. 


(` Use existing stored procedures 


Choose an existing stored procedure for each operation (selecting, inserting, updating and deleting 
records). 


> Previous | nexe >_ [ ES | Cancel | 





هذه النافذة تتيح لك اختيار واحد مما يلي: 
o‏ استخدام جمل .(Use SQL Statements) SQL‏ 
ه إنشاء إجراءات مخزنة جديدة .(Create New Stored Procedures.)‏ 
ه استخدام إجراءات مخزّنة موجود سابقا في قاعدة البيانات 
.(Use Existing Stored Procedures)‏ 
ويُخدد اختيارك» النافذة الثالية اى ستظهر عدا تفط الزن وا وذلك 
كالتالي: 


ال 


- إذا اخترت استخدام جملة 501 أو إنشاء إجراء مخزن جديدء فستظهر لك 
النافذة التالية: 


| 
Data Adapter Configuration ¥#izard ادا‎ 


Generate the stored procedures 


The SELECT statement will be used to create the SELECT, INSERT, UPDATE, and 
DELETE stored procedures. 


Type your SQL statement or use the Query Builder to construct it, What data should be loaded into the table? 
What data should the data adapter load into the DataSet? 









SELECT Authors, Author, Books, Book 
FROM Authors INNER JOIN 
ا‎ Books OJ Authors. ID = Books. AuthorID 


Advanced Options... | 


< Previous | Next > | Finish | Cancel | 





هذه النافذة تقدم لك مربع نص تستطيع أن تضيف فيه يدويا أو باللصق» 
نص جملة الاستعلام أو جملة إنشاء الإجراء المخزن الجديد. 

ويمكنك ضغط الزرٌ 281110161 :00613 لاستخدام باني الاستعلام في إنشاء 
جملة ,5001.» وعند إغلاق باني الاستعلام ستجد هذه الجملة مضافة إلى 
مربع النص.. لاحظ أن هذا الزر موجود أيضا في حالة إنشاء إجراء 
مخزن جديدء لأنك قد تحتاج إلى إضافة جملة استعلام داخل الإجراء 
المخزن» لهذا من الأسهل أن تنشئ هذه الجملة بباني الاستعلام» ثم تضيف 
إلى مربع النص بعد هذا صيغة الإجراء المخزن الذي يحتويها.. وإن كنت 
أنصحك بعدم إنشاء الإجراءات المخزنة بهذه الطريقة» لأن إنشاء الإجراء 
المخزن باستخدام متصفح الخوادم 1ع101م152 ه53 أسهل وأفضل 
الإجراء المخزن» واختبار نتائجه. 


€۷ 


ملحوظة: 
لا يسمح المعالج السحري بكتابة أكثر من جملة ,501 مفصولة بالعلامة 
: جرب مثلا استخدام الجملة التالية لملء مجموعة البيانات بجدولي 
المؤلفين والكتب كاملين: 
SELECT * FROM Authors;‏ 
SELECT * FROM Books‏ 
لو ضغطت الزر ٥×‏ فستظهر نافذة تخبرك بوجود خطأ في جملة 
الاستعلام» وسترفض مواصلة الخطوات ما لم تصحح هذا الخطأ. 
لكن لو كنت مصرا على وضع أكثر من جملة استعلام في موصل 
البيانات» ليقوم بملء مجموعة البيانات بأكثر من جدولء فاتبع الخطوات 
التالية: 
- حدد موصل البيانات في صينية مكونات النموذج» واضغط ۴4 
و اف اخ اکن 
- حدد الخاصية 5160100112120 في نافذة الخصائص» 
واضغط العلامة + المجاورة لها لإسدال خصائص كائن الأمر. 
- حدد الخاصية 206 021201تدزه0)» واكتب في قيمتها جملة 
الاستعلام المكونة من أكثر من أمر. 
- اضغط زر الحفظ أو انتقل إلى أي خاصية أخرى أو إلى 
النموذج.. ستظهر رسالة تسألك إن كنت تريد تحديث معاملات 
هذا الامن:. اضفظ زر المواققة. 
الآن سيكون كل شيء على ما يرام» وسيملأ موصل البيانات مجموعة 
البيانات بجدولي المؤلفين والكتب! 
الطريف أنك لو أعدت فتح المعالج السحري فستجد جملة الاستعلام 
المركبة من أكثر من أمر معروضة في مربع النص» ولكنك ستظل 
تحصل على خطأ لو حاولت الانتقال إلى الخطوة التالية! 








وتحتوي هد النافذة أيضا على الزر "خيارات متقثمة" 
Advanced Options‏ ولو ضغطته فستظهر لك نافذة بها الخيارات 
التالية: 


€۸ 











ع سس havancedoptions‏ 


Additional Insert, Update, and Delete statements canı be generated to update the data 
source, 


¥ Generate Insert, Update and Delete statements 
Generates Insert, Update, and Delete statements based on your Select statement. 
WV Use optimistic concurrency 
Modifies Update and Delete statements to detect whether the database has changed 
since the record was loaded into the dataset, This helps prevent concurrency conflicts, 
IV Refresh the DataSet 
Adds a Select statement after Insert and Update statements to retrieve identity column 
values, default values, and other values calculated by the database, 


| اعت 





:Generate Insert, Update And Delete Statements .١ 
استخدم هذا الخيار إذا كان برنامجك سيجري تعديلات في السجلات‎ 
التي يحملها من قاعدة البيانات.. في هذه الحالة سيتمٌ إنتاج جمل‎ 
التحديث والإدراج والحذف آلياء بالاعتماد على أسماء الجداول‎ 

والأعمدة الموجودة في جملة 561601 التي أنشأتها. 

؟. استخدم التطابق المتفائل :Use Optimistic Concurrency‏ 
هذا الخيار يتيح لك استخدام التطابق المتفائل عند تحديث البيانات.. 
لاحظ أن إزالة علامة الاختيار يعني أنك تريد استخدام التطابق 
114 لكنه لن يكتب لك الكود المناسب لإغلاق 
)عم سجلات قاعدة البيانات» وعليك أن تكتب هذا الكود بنفسك من 

خلال كائن التعاملات ]ع 066 Transaction‏ . 

*. إنعاش مجموعة البيانات :Refresh The DataSet‏ 
هذا الخيار يضيف جملة تحديد 5181101 بعد جملتي الإدراج 
والتحديث» وذلك لإنعاش مجموعة البيانات بعد تنفيذ أوامر الإدراج 
والتحديث» كما شرحنا سابقا.. لاحظ أن هذا الخيار غير متاح في 
قواعد بيانات ووعععك4رء: وذلك لأنه لا يسمح أصلا بتنفيد أكثر من 
استعلام في المرة الواحدة. 


أما لو اخترت استخدام إجراءات مخزنة موجودة سابقا في قاعدة البيانات» 
فستظهر لك النافذة التالية: 


۹ 


Data Adapter Configuration ¥izard 2× 


Bind Commands to Existing Stored Procedures 


Choose the stored procedures to call and specify any required parameters. 


Select the stored procedure for each operation, If the procedure requires parameters, specify which column 
in the data row contains the parameter value, 


Set Select procedure parameters: 


Select: 
> Data Column 
GetAuthorBooks) 

Book 





< Previous | nee> | Finish | Cancel | 


هذه النافذة بها أربع قوائم منسدلة؛ تعرض کل منها أسماء الإجراءات 
المخزنة الموجودة في قاعدة البيانات» لتختار منها إجراء للتحديد Select‏ 
والإدراج 116ه»وم1 والتحديث ءلمل والحذف م16ه1ه12. 

ويوجد على يمين النافذة جدول يعرض بعض التفاصيل الخاصة بالإجراء 
المخزن.. فبالنسبة للإجراء الخاص بالتحديد» يعرض الجدول أسماء 
الأعمدة التي يعيد الإجراء المخزن محتوياتها (على سبيل المثال: الإجراء 
65 4غ يعيد العمود ع800[1» الذي يحتوي على أسماء الكتب 
الخاسية بالمولف: الطاب 


أما بالنسبة لإجراءات الإدراج والتحديث والحذف» فيعرض هذا الجدول 
عمودين» أولهما يحتوي على المعاملات المعرفة ئ الإجراء المخزن»› 
والثاني يحتوي على أسماء حقول مجموعة البيانات» التي سيتم ملء هذه 
المعاملات من قيمها لإرسالها إلى الإجراء المخزن.. وتحتوي كل خانة في 
هذا العمود على قائمة منسدلة يمكنك اختيار اسم الحقل منها. 1 





وبعد الانتهاء من أي من النافذتين السابقتين» سيؤدي ضغط الزر ×" إلى ظهور 
نافذة تعرض ملخصا لخياراتك.. اضغط الزر طوام۴ لإنهاء المعالج السحري 
وتنفيذ هذه الاختيارات» أو اضغط [عع0') لإلغاء العملية. 

لاحظ أنك تستطيع في كل نافذة من نوافذ هذا المعالج» الرجوع إلى النافذة السابقة 
بضغط الزر 1”1710115. 

بعد انتهاء المعالج ستجد أن خصائص موصل البيانات قد تم ضبطها لتوافق 
اختياراتك» كما ستجد كائن اتصال 50100112601101 اسمه الافتراضي 
01 قد أضيف إلى صينية مكونات النموذج» ليستخدمه موصل 
البيانات في الاتصال بقاعدة البيانات. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


فئة باني أوامر قاعدة البيانات 
DbCommandBuilder Class‏ 


هذه الفئة هذه الفئة أساسية مجردة و6125 728396 4652061 »: تجب وراثتها 
»Must]nherit‏ وهي ترت فئة المكون 01255 00110012616)» ويمكنك استخدامها 
لبناء أوامر التحديث والإدراج والحذف اللازمة لنقل التغييرات من أحد جداول 
نجموعة البياناث وو وون إلى قاعذة البوانات:. و لكى قعل هذه اة حن عليك 
ربطها بموصل البيانات» بشرط أن يحتوي موصل البيانات على أمر التحديد 
Command‏ "8158001 5.. وتقوم هذه الفئة بالاستجابة للحدث RowUpdating‏ 
الخاص بموصل البيانات» حيث تستخلص المعلومات الأساسية عن تركيب الصف 


من أمر التحديی د SELECT Command‏ 
(كاسم الجدول وأسماء الأعمدة)» وتبني الأمر المناسب لتحديث أو حذف أو إدراج 
السجل الذي أطلق الحدث. 


ويتم ربط موصل بيانات واحد فقط بباني أوامر واحد فقط. 
وتمتلك هذه الفئة الخصائص التالية: 


:Data Adapter موصل البيانات‎ 3 

تقرأ أو تغير موصل البيانات الذي سيتم إنشاء أوامره.. لاحظ أن موصل 

البيانات يجب أن يحقق الشروط التالية: 

.SELECT Co 1and أن يحتوي على أمر تحديث‎ -١ 

- أن يكون ضمن أعمدة النتيجة التي يعيدا أمر التحديد المفتاح الأساسي أو 
عمود متفرد ©21011[] يميز كل صف. 

۳- أن يعيد أمر التحديد النتائج من جدول واحد فقط.. استعلامات الربط بين 
أكثر من جدول مرفوضة. | ا 

وعند الإخلال باي من هذه الشروط؛ سيحدث خطأ ويرفض باني الأوامر إنتاج 

أوامر التحديث والحذف والإدراج.. ويمكنك استدعاء الوسيلة موم ءز5 

الخاصة ببانى الأوامرء لإنهاء ارتباطه بموصل البيانات» والوقوف عن 

استخدام الأوامر التي أنشأها. 


وجا وضع جميع القيم وع1117211[ماء5: 

إذا a‏ قيمتها 106» ينتج باني الأوامر أمر تحديث 11001216 يحدث جميع 
قيم السجل.. أما إذا جعلتها 172156 فسينتج أمر تحديث يحدث فقط قيم الحقول 
التي تغيرت في مجموعة البيانات.. لاحظ أن باني الأوامر يتابع الحدث 
5 الخاص بموصل البيانات» يفحص كل صف قبل تحديثهء 
ومن ثم ينتج استعلام التحديث المناسب لهذا الصف تبعا للتغييرات التي حدثت 
فيه في مجموعة البيانات. 

طبعا هذا أذكى وأسرع وأقل عبئا على خادم سيكويل» لكنه قد يؤدي إلى نتائج 
غير متوقعة إذا كنت تحل مشاكل التوافق Concurrency Conflicts‏ 
باستخدام طريقة "الأخير يكسب"» بحيث تحفظ تغييراتك مباشرة»ء فهذا قد 
يجعل قيم السجل تتكون من مزيج من تغييراتك وتغييرات مستخدم آخر.. أما 
إذا كنت تستخدم طابع الوقت أو تقارن كل الحقول» فلا خوف من هذه 
المشكلة 


وع خيار التعارض 012111260711012 6©: 
تحدد كيف يتم إنشاء أمر التحديث 1721717 والحذف 101115711 لتلافي 
مشاكل التطابق 20111015© '00210116203.. وتأخذ هذه الخاصية إحدى قيم 
المرقم 1410م002111610) التالية: 


CompareAll‏ يتم البحث عن السجل المراد تحديثه فى قاعدة 
65 البيانات؛ بمقارنة جميع قيم الحقول العددية 
والنصية الصغيرة» للتأكد من أن السجل لم تدخل 
عليه أية تعديلات. 
Compare‏ يتم البحث عن السجل المراد تحديثه في قاعدة 
RowVersion‏ البيانات» بمقارنة حقل الإصدار.. هذا يتطلب 
وجود حقل من النوع مصه٤؟٥ء‏ "ص11 في الجدول. 


Overwrite‏ يتم البحث عن السجل المراد تحديثه في قاعدة 
Changes‏ البيانات» باستخدام مفتاحه الأساسي فقطء وهذا 
يعني أن التغييرات الخاصة ببرنامجك سيتم 
حفظها في السجل لتلغي أية تغييرات أدخلها 











3 قوس الفتح :Quote Prefix‏ 
تقرأ أو تغير النص المستخدم كقوس فتح» لاستخدامه مع أسماء الجداول 
والأعمدة التي تحتوي على مسافات أو حروف غير مقبولة. 


Yor 














قوس الإغلاق :QuoteSuffix‏ 
تقرأ أو تغير النص المستخدم كقوس إغلاق. 
مع قواعد البيانات المألوفة» يكون قوسا الفتح والإغلاق [ ]. 


وخ موضع الفهرس :Catalog Location‏ 
تقرأ أو تغير الموضع الذي سيوضع فيه اسم قاعدة البيانات» عند تكوين 
المسارات الكاملة لأسماء الجداول في أوامر .501.. وهي تأخذ إحدى قيمتي 
المرقم 21101ع100ع034210) التاليتين: 


| يوضع اسم قاعدة البيانات في بداية المسار. 
4 | يوضع اسم قاعدة البيانات في نهاية المسار. 











وخ فاصل الفهرس 212105567212601 ©: 
أو تغير النص المستخدم كفاصل بين اسم قاعدة البيانات واسم الجدول عند 
كتابة المسار الكامل.. المألوف أن تستخدم النقطة . كفاصل» متل 
Books.Author‏ . 


وخ فاصل المخطط :SchemaSeparator‏ 
تقرأ أو تغير النص المستخدم كفاصل بين اسم المخطط 51161718 واسم 
معرف 116161 موجود في هذا المخطط.. والمألوف أن تستخدم النقطتان 
المتعامدتان : كفاصلء مثل: .Person:CustonerName‏ 


كما شلك هذه الفكة الوسائل: الثالية: 


7# إنعاش المخطط :RefreshSchema‏ 
تحذف أوامر التحديث والحذف والإدراج التي قام باني الأوامر ببنائها.. هذا 
البيانات» حيث إن باني الأوامر يبني أوامره بعد أول عملية تحديث لقاعدة 
البيانات» ويستخدمها كما هي بعد هذا.. لهذا عليك استدعاء هذه الوسيلة إذا 
قمت بتغيير استعلام التحديد أو وقت الانتظار CommandTimeout‏ 
أو كائن التعاملات Transaction‏ الذي يستخدمه أمر التحديدء لكي يعيد باني 
الأوامر إنشاء أوامر التحديث والحذف والإدراج لتلائم هذه التغييرات. 


ا معرفة أمر التحديث :GetUpdateCom and‏ 


of 











0 


تعيد كائن الأمر 015030 1(50 الذي تم إنتاجه لتحديث قاعدة البيانات. 
وهناك صيغة ثانية لهذه الوسيلةء تستقبل معاملا منطقياء إذا جعلته ©12[15: 
فسيستخدم باني الأوامر في أمر التحديث» معاملات لها الأسماء ۲1 و 72 
و 23 وهكذا... (مثل 021©) = 6مطننركم '581).. وهذه هي الحالة 
الافتراضية في الصيغة الأولى لهذه الوسيلة. 
أما إذا جعلت قيمة هذا المعامل 6ن1؛ فسيتم إنتاج معاملات لها نفس أسماء 
الأعمدة » كلما كان هذا ممكنا (مثل ..)SET Author = @Author‏ لاحظ 
أن محاولة إنتاج هذه الأسماء ستسبب خطأ إلا إذا جعلت كائن 
210212001110165 يلتزم بالشروط التالية: 
-١‏ تحديد أقصى طول ممكن لأسماء المعاملات» من خلال الخاصية 
.ParameterNameMaxLength‏ 
۲- توضصيح صيغة أسماء المعاملات» عن خلال الخاصية 
.ParameterNamePattern‏ 
۳- تحديد تنسيق العلامة المميزة للمعامل» من خلال الخاصية 
.ParameterMarkerFormat‏ 





معرفة أمر الإدراج :GetInsertCom mand‏ 

تعيد كائن الأمر 150001713220 الذي تم إنتاجه لإدراج صف جديد في 
قاعدة البيانات.. وهي مماثلة في صيغتيها للوسيلة 
.GetUpdateCommand‏ 


معرفة أمر الحذف :GetDeleteCom mand‏ 
تعيد كائن الأمر 160001711220 الذي تم إنتاجه لحذف صف من قاعدة 
البيانات.. وهي ممائلة في صيغتيها للوسيلة .GetUpdateComnmand‏ 


7# تقويس المعرف :QuoteIdentifier‏ 
أرسل إلى هذه الوسيلة نصا يمثل مسارا كاملا لأحد عناصر قاعدة البيانات 
(مثل «01.11ط]ت1ى.و8001)» لتعيد إليك نفس المسار بعد وضع كل أسماء 
العناصر الموجودة فيه بين قوسين (مثل ]10[ ..([Books].[Author].‏ 
لاحظ أن المعرف المحاط بقوسين فعلا سيتم تجاهله. 


#> إزالة تقويس المعرف :Unquote1Identifier‏ 
أرسل إلى هذه الوسيلة نصا يمثل مسارا مقوسا لأحد عناصر قاعدة البيانات 
(مثل [800125[.].411501[.]110])» لتعيد إليك نفس المسار بعد إزالة جميع 
الأقواس منه (مثل .(Books.Autho1.15‏ 


:DbCommandBuilder والفئات التالية ترث الفئة‎ 
.OdbcCommandBuilder Class .١ 
.OleDbCommandBuilder Class ؟.‎ 
.OracleCommandBuilder Class .Y 
.SqlCommandBuilder Class .“ 


وسنتعرف هنا فقط على الفئة .SqlCommandBuilder‏ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


4 فنة باني أوامر سيكويل 
SqlCommand Builder Class‏ 


هذه الفئة ترث الفئة 0mmandBu ¡1de‏ €( وهي تمتلك نفس خصائصها 
ووسائلهاء مع فارق بسيط أنها مخصصة للتعامل مع سيكويل سيرفر وأوامره 
.SqlCommand‏ 
ولحدث إنشاء هذه الفئة صيغتان: 
-١‏ الأولى بدون معاملات. 
"- والثانية تستقبل موصل البيانات :وع1م 50110324013 الذي سيرتبط به باني 
الأو امو 


وتمتلك هذه الفئة الوسيلة الجديدة التالية: 


5 > اشتقاق المعاملات :DeriveParameters‏ 

أرسل إلى هذه الوسيلة كائن أمر 50100577310 مجهز لتنفيذ إجراء 
مخزن» لتقوم هذه الوسيلة بالاتصال بقاعدة البيانات» والحصول لئ معلومات 
عن معاملات الأجراء المخزنء واستخذامها لإضافة المعاملات المتاسبة غلى 
مجموعة المعاملات 2م1]ء ©0116 Parameters‏ الخاصة بكائن الأمر.. 
لاحظ أن خطأ سيحدث لو أرسلت إلى هذه الوسيلة كائن أمر يتعامل مع 
استعلام 5010 أو يحتوي على اسم إجراء مخزن غير صحيح. 

ويعيب هذه الوسيلة أنها تحتاج إلى الاتصال بقاعدة البيانات مرة إضافية 
لإحضار بيانات المعاملاتء لأنك بالتأكيد ستتصل مرة ثانية لتنفيذ الأمر. 


والمشروع 0111110161 ةدمدطه© يريك مثالا على استخدام هذه الفئة لإنتاج أوامر 


خرائط البيانات :Data Mapping‏ 
يتيح لك موصل البيانات عمل خراط للجداول Mapping‏ ©1]1» وذلك بإعادة 
تسمية الجداول والأعمدة بأسماء خاصة بك» وربطها بالأسماء الحقيقية في قاعدة 


البيانات.. 
-١‏ 


-۲ 
3 


هذا يحقق لك الفوائد التالية: 
تغيير أسماء الجداول أو الأعمدة في مجموعة البيانات كما يناسب 
برنامجك» دون العبث بقاعدة البيانات الأصلية. 
عرض أسماء الأعمدة للمستخدم بالطريقة التي تناسبك. 
إذا كان لديك جدولان لهما نفس الاسم في قاعدتي بيانات مختلفتين» فإن 
بإمكانك إضافتهما إلى نفس مجموعة البيانات» وذلك بتغيير اسميهما من 
خلال خريظة الجدول الخاصبة يكل متهم 


وتنقسم خرائط البيانات إلى نوعين: 


-١ 


خريطة الجدول :Table Mapping‏ 
حيث تكون لكل جدول خريطة»ء يذكر فيها اسمه الأصلي في قاعدة البيانات 
واسمه الجديد في مجموعة البيانات. . وتوضع خرائط الجداول في 

المجموعة TableMappings‏ في موصل البيانات. 

وهناك نقطة هامة يجب أن تنتبه إليها عند إنشاء هذه الخرائط هي ان 
موصل البيانات يعطي أسماء افتراضية للجداول» تختلف عن أسمائها 
الأصلية (مثل 1216 و 1861»1... إلخ).. هذا قد يسبب لك ارتباكا وأنت 
تنشئ خرائط الجداول» فستبدو لك وظيفتها عكسية»ء فبدلا من أن تعطي 
الجدول الأصلي اسما جديداء ستحاول أن تعيد تسمية الاسم الافتراضي 
الخاضن يموضيل الات بام الحدؤل الأضلي] 

لكن يقليل من التأمل» ستفهم لماذا بقل مو صل البيانات هذا فاد 
التحديد في معظم الحالات لا يعيد جدولا من قاعدة البيانات» بل قد يعيد 
أجزاء من عدة جداول (كما في حالة الربط (Joining‏ أو قد يعيد نتائج 
محسوبة من جدول أو أكثر (كما في حالة التجميع 1 ). . لهذا 
يريح موصل البيانات نفسه من كل هذه الاحتمالات المعقدة ويسمي 
الجداول الناتجة من الاستعلام بأسماء افتراضيةء ويترك لك حرية إنشاء 
خريطة الجداول التي تصحح فيها الأسماء بطريقتك. 

والمشروع عمإممهN‏ يريك مثالا على هذا. . فنحن نستخدم استعلام ربط 
يعيد المؤلفين وكتبهم.. نتيجة هذا الاستعلام ستحتوي على جدول مخلق» 
دة مو لاما الاسم الاقتر کی وااو لهذا استخدسا رة 
الجدول لإعادة تسميته .Authors-Books‏ 


؟"- خريطة العمود :Column Mapping‏ 
حيث تكون لكل عمود خريطةء يذكر فيها اسمه الأصلي في قاعدة البيانات 
واسمه الجديد في مجموعة البيانات.. وتوضع خرائط الأعمدة في 
المجموعة وع15م[م3/لمدمطن[00) في خريطة الجدول الذي تنتمي إليه. 
ولا يحتاج موصل البيانات إلى تسمية الأعمدة بأسماء افتراضية» أسبب 
بسيط: هو أن كل عمود يتم ذكره صراحة في استعلام التحديد» وحتى 
الأعمدة المولدة (الأعمدة المحسوبة) يتم تسميتها إجباريا باستخدام الفقرة 
ومء لهذا فإن موصل البيانات يعرف يقينا اسم كل عمود في النتيجة.. ولا 
يتدخل موصل البيانات لإعادة تسمية العمودء الا فى حالة وجود عمودين 
بنفس الاسم (يمكن أن يحدث هذا لو كنت تستخدم أكثر من جملة 
1077 في أمر التحديد مثلا). 
وأهم استخدام لخرائط الأعمدة» هو إعادة تسمية الأعمدة بطريقة تصلح 
لعرضها للمستخدم.. والمشروع ع15مم713 يريك مثالا على هذاء حيث 
استخدمنا خريطة الأعمدة لإعادة تسمية العمود 1101 بالاسم "المؤلف", 
والعمود 80015 بالاسم "الكتاب".. هذان الاسمان سيظهران في جدول 
العرض وهذا مناسب للمستخدم العربي للبرنامج. 


لاحظ أنك بعد عمل خرائط الربط» ستستخدم اسم الجدول الجديد واسمي العمودين 
العربيين في الكود عند التعامل معهما من خلال مجموعة البيانات.. مثلا: 
Dim T = Ds.Tables("Authors-Books'"")‏ 
MsgBox(T.Columns('dial!'").MaxLength)‏ 
في الحقيقة هناك حل آخر لعرض أسماء الأعمدة بأسماء عربية دون استخدام 
خريطة الأعمدةء وذلك باستخدام خصائص جدول العرض نفسه لإعادة تسمية 
عنوان العمود» كما سنرى فيها بعد. 


والآن» فلنتعرف على خرائط الجداول والأعمدة» وكيفية استخدامها.. وسنتفق هنا 
على استخدام التعبير "اسم الجدول الأصلي" للإشارة إلى الاسم الذي يمنحه موصل 
البيانات للجدول» مع ملاحظة أن هذا الاسم حساس لحالة الأحرف.. كما سنستخدم 
التعبير "اسم العمود الأصلي" للإشارة إلى اسم العمود في قاعدة البيانات» أو الاسم 
البديل الذي سماه به موصلا البيانات إن حدث تعارض بين عمودين» مع ملاحظة 
أن هذا الاسم غير حساس لحالة الأحرف. 


5 


۱ عة خرائط الجدا 
ITableMappingCollection Interface‏ 


هذه الواجهة ترث واجهة القائمة †و]؛ وهي قائمة تحتوي على خرائط الجداول. 
وإضافة إلى ما ترثه من واجهة القائمة من عناصرء تمتلك الوسيلة الوحيدة التالية: 


#< معرفة الخريطة من جدول مجمو عة البيانات 41e‏ ¢1؟GetByDat4:‏ 
أرسل إلى هذه الوسيلة اسم جدول موجود في مجمو عة البيانات 210348561 
لتعيد إليك كائنا تمثل الواجهة ع108مم11216713» يحتوي على خريطة هذا 
الجدول.. ومن المتوقع أن يكون هذا الكائن من نوع الففة 
15 اسلتي سنتعرف عليها لاحقا. 

كما تضيف هذه الواجهة صيغة أخرى لبعض عناصر القائمة التقليدية» مثل: 


العنصر 1ر1 
تستقبل الصيغة الثانية لهذه الخاصية اسم الجدول الأصلي (وهو حساس لحالة 
الأحرف)» وتعيد كائنا 4م ز06 يحتوي على خريطة هذا الجدول إن وجدت 
في القائمة» وإن لم توجد فسيحدث خطأ. 
كما يمكنك استخدام هذه الخاصية لتغيير كائن خريطة الجدول» فهي قابلة 
للقراءة وللكتابة أيضا. 


© إضافة 400: 
تستقبل الصيغة الثانية لهذه الوسيلة معاملين نصيين وعما)؟» أولها هو اسم 
الجدول الأصلي (وهو حساس لحالة الأحرف 56)زومه0356-56).» وثانيهما 
هو اسم الجدول في مجموعة البيانات.. وتقوم هذه الوسيلة بإنشاء كائن خريطة 
جدول 123431361671318 يمثل العلاقة بين الجدولين وتضيفه إلى 
القائمة» وتعيد نسخة من الواجهة ITableMapping‏ تشير إلى هذا الكائن. 


7# تحتوي على 05ز)02©: 


تستقبل الصيغة الثانية لهذه الوسيلة اسم الجدول الأصليء وتعيد ع1 إذا 
كانت هناك خريطة لهذا الجدول في القائمة. 


۰ 


> رقم العنصر 12016201: 

تستقبل الصيغة الثانية لهذه الوسيلة اسم الجدول الأصليء وتعيد رقم الخانة 
التي يوجد بها كائن خريطة هذا الجدول في القائمة إن وجدء أو تعيد ١-‏ إن لم 
توجد خريطة لهذا الجدول. 


> حذف من موضع ٥0۷۵۸۲‏ ۸: 
شاا 1 5 3 الثانية لهذه الوسيلة اسم الجدول الأصلي »> وتبحث في القائمة 
عن كائن خريطة هذا الجدول» وتحذفه إن وجدته. 


ملحوظة: 

هذه الصيغة تبدو مختلفة في وظيفتها عن الصيغة الأولى المألوفة» التي 
تستقبل رقم خانة في القائمة وتحذفها لإزالة خريطة الجدول الموجودة بها من 
القائمة.. وإن شئت رأييء كان المنطقي أن تكون هذه الصيغة الجديدة هي 
الصيغة الثانية للوسيلة 16172057 ولیس رء:1161707 منعا للالتباس!! 








اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


لم 











58 فئة مجموعة خرائط الجداول 
DataTableMappingCollection Class‏ 


هذه الفئة تمثل الواجهة م0ن†ءع 11اه €٣عinمeMappاabا]»‏ وهي تعمل كقائمة» 
عناصرها من نوع الفئة عزمم 1732312616712 التي سنتعرف عليها بعد قليل. 
وإضافة إلى ما ترثه من الواجهة 10100ع»15800116مم1135167/13 والواجهة 
4 من خصائص ووسائلء تمتلك هذه المجموعة الوسيلتين الجديدتين التاليتين: 


5 معرفة خريطة الجدول :GetTableMappingBySchem4۸ction‏ 
تبحث في مجمو عة الخرائط عن الخريطة التي تربط بين اسم الجدول الأصلي 
واسم الجدول في مجموعة البيانات» فإن وجدته تعيد كائنا من النوع 
6 يمثل هذه الخريطة.. وتستقبل هذه الوسيلة 
المعاملات الثالية بالثرتيب» 

- مجموعة خرائط الجداول Data ableMappingCollection‏ التي سيتم 


البحث فيها. 


د أن الخذرل ا ا 

د اسم الجدول قن مسموظة النيانات: 

- إحدى قيم المرقم 10]ء ىع 10م م12 ع7115510 التي تحدد ماذا سيحدث إذا 
لم تكن خريطة الجدول موجودة» كما هو موضح في الجدول التالي: 


Passthrough 


Ignore 
Error 








يتم إنشاء خريطة جدول جديدة تحمل اسم الجدول 
الأصلى المرسل ف المعامل الأرل: واس جدول 
مجموعة البيانات المرسل في المعامل الثاني. 

يتم تجاهل الخطأء وتعيد الوسيلة عم1طاه. 

يم إطلاق خط ا بن اللسوع 
.InvalidOperationException‏ 





ب رقم جدول مجمو عة البيانات l]eۆIndexOfDataSetTa:‏ 
أرسل إلى هذه الوسيلة اسم الجدول في مجموعة البيانات» لتعيد إليك رقم 
خريطة الجدول في مجموعة الخرائط الحالية.. وتعيد هذه الوسيلة ١-‏ إذا لم 
تعثر على خريطة هذا الجدول. 


1۲ 














2-2 واجهة خريطة الجدول 
ITableMapping Interface‏ 


تمتلك هذه الواجهة الخصائص اللازمة لرسم خريطة الربط بين الجدول الأصلي 
والجدول الموجود في مجمو عة البيانات.. وهذه الخصائص هي: 


ونج جدول المصدر :Source Table‏ 
تقرأ أو تغير اسم الجدول الأصلي. 


ونج جدول مجموعة البيانات 6461816 122625: 
تقرأ أو تغير اسم الجدول في مجموعة البيانات. 


“57 نز خرائط الأعمدة :ColumnMappings‏ 
تعيد كائنا يمثل واجهة خرائط الأعمدة «‘[ColumnMappingCollection‏ 
وهو تحديدا من نوع الفئة ec†10‏ ]1٣ع‏ umnMappinا€0»‏ التي يمكنك أن 
تضيف إليها خرائط الربط بين الأعمدة. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النار» وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


1 


-١ 
1 


3 


وا 


Data TableMapping Class فئة خريطة الجدول‎ 42 


هذه الفئة تمثل الواجهة ع1زمم1(31313167/13» وهي تحتوي على المعلومات 
اللازمة لربط الجدول في مجموعة البيانات بالجدول الأصلي. 

ولحدث إنشاء هذه الفئة ثلاث صيغ: 1 

الصيغة الأولى بدون معاملات. 

والصيغة الثانية تستقبل اسم الجدول الأصلي واسم الجدول في مجموعة 


البيانات. 


والصيغة الثالثة تزيد على الصيغة السابقة بمعامل ثالث» يستقبل مصفوفة 
من النوع ع10مم2113ا1(32001: تحتوي على معلومات الربط بين 


هذه الفئة هذه الوسائل الجديدة: 


> معرفة عمود البيانات :GetDataColumn‏ 
تعيد كائن عمود البيانات 1233001111 الذي يمثل العمود المحدد 
بالمعاملات المرسلة» وهي بالترتيب: 


كائن النوع عم1577 الذي يمثل نوع هذا العمود. 

كائن الجدول 123431216 الذي يمثل الجدول في مجموعة البيانات. 

إحدى قيم المرقم ٣4101‏ 1مم MissingM a‏ التي تحدد ماذا سيحدث لو 
لم يتم العثور على العمود في خريطة الجدول.. وقد تعرفنا على قيم هذا 


المرقم سابقا. 


إحدى قيم المرقم 113/46110ع 211551255 التي تحدد ماذا سيحدث لو 
لم يتم العثور على العمود في مخطط الجدول »Schema‏ وهذه القيم هي: 


Add 
AddWithKey 


Ignore 
Error 








يضاف العمود إلى مخطط الجدول. 

يضاف العمود والمفتاح الأساسي Primary Key‏ 
إلى مخطط الجدول. 

يتم تجاهل العمود. 
.InvalidOperationException‏ 


1٤ 




















#> معرفة الجدول :GetDataTableBySchema۸ction‏ 
تعيد كائن جدول البيانات 123421816 الموجود في مجموعة البيانات» 
والمذكور اسمه في خريطة الربط.. وتستقبل هذه الوسيلة معاملين: 
- كائن مجموعة البيانات +©1026256. 
- إحدى قيم المرقم 401010 ة172عطاء 7211551285 التي توضح التصرف 
المناسه إذا لم يتم العثور .على هذا الحدول في مجموعة البيانات. 


7# معرفة خريطة العمود :GetColumnMappingBySchema۸Action‏ 
تعيد كائن خريطة العمود ع10مم1/12تد 1231800011 للعمود الذي تريدجه. 
- إحدى قيم المرقم 10]ء كارع Missing Mapp‏ الذي تعرفنا عليه من قبلء 
والتي توضح رد الفعل إذا لم يتم العثور على هذا العمود. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


1° 


هذه الواجهة ترث واجهة القائمة +11.15» وهي تملك وسيلة وحيدة جديدة» وهي: 


© واجهة مجموعة خريطة العمود 
IColumnMappingCollection Interface‏ 


معرفة الخريطة بواسطة عمود مجمو عة البيانات :GetByDataSetColumn‏ 
أرسل إلى هذه الوسيلة اسم العمود في مجموعة البيانات» لتعيد إليك كائنا يمثل 
واجهة خريطة العمود ع11زمم01/13دن1001 الذي يحتوي على معلومات 
ربط هذا العمود بالعمود الأصلي.. وسيكون هذا الكائن من نوع الفئة 
DataColumnMapping‏ تحديدا. 


وتضيف هذه الواجهة صيغة أخرى لبعض خصائص ووسائل القائمة التقليدية: مثل: 


3 العنصر 22رع)1: 


تستقبل الصيغة الثانية لهذه الخاصية اسم العمود الأصلي (وهو حساس لحالة 
الأحرف 10056وم0356-56).» وتعيد كائنا ]06160 يحتوي على خريطة هذا 
العمود إن وجدت في القائمة» وإن لم توجد فسيحدث خطأ. 


إضافة 400: 

تستقبل الصيغة الثانية لهذه الوسيلة معاملين نصيين وع1غ5»: أولها هو اسم 
العمود الأصليء وثانيهما هو اسم العمود في مجموعة البيانات.. وتقوم هذه 
الوسيلة بإنشاء كائن خريطة أعمدة ع امم 2)المدصن1ه 12220 يمثل العلاقة 
بين العمودين وتضيفه إلى القائمة» وتعيد نسخة من الواجهة 
umnMappingا0]‏ تشير إلى هذا الكائن. 


تحتوي على 002]2[125): 
الأحرف)»ء وتعيد 156 إذا كانت هناك خريطة لهذا العمود في القائمة. 


1 


7# رقم العنصر 170601: 
تستقبل الصيغة الثانية لهذه الوسيلة اسم العمود الأصليء وتعيد رقم الخانة التي 
يوجد بها كائن خريطة هذا العمود في القائمة إن وجدء أو تعيد ١-‏ إن لم توجد 


خريطة لهذا العمود. 


حذف من موضع :۸e 0۷٥۸۲)‏ 
تستقبل الصيغة الثانية لهذه الوسيلة اسم العمود الأصليء وتبحث في القائمة 
عن كائن خريطة هذا العمود» وتحذفه إن وجدته. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


1۷ 


9 فة مجموعة خريظة الود 
DataColumnMappingCollection Class‏ 


هذه الفئة تمثل الواجهة 100]ء118000116مم0113د1)0011» وهي تعمل كقائمة 
تحتوي على كائنات من نوع الفئة ع12[مم13/متدطنن1ه10330»: التي ترسم خرائط 
الربط بين أعمدة مجموعة البيانات والأعمدة الأصلية. 

واک لے فعا اا من کا ول الو ا 
Collection‏ umnMappingا0]»‏ تمتلك هذه الفئة الوسائل التالية: 


© # معرفة عمود البيانات :GetDataColumn‏ 
مماثلة للوسيلة GetData Column‏ الخاصة بالفئة «DataTableMapping‏ 
مع فارق وحيدء هو أنها هنا وسيلة مشتركة لعإهط؟» لهذا تمتلك معاملا 
زائداء هو المعامل الأول الذي يستقبل مجموعة خرائط الأعمدة 
21 )1-0-1 التي سيتم البحث فيها. 


© 19> معرفة خريطة العمود :GetColumnMappingBySchema۸Action‏ 
ممائلة للوسيلة GetColumn MappingBySchemaAction‏ الخاصة 
بالفئة ع1م 10221261633 مع فارق وحيد» هو أنها هنا وسيلة مشتركة 
4 لهذا تمتلك معاملا زائداء هو المعامل الأول الذي يستقبل مجموعة 
خرائط الأعمدة نهنا 1118500116مم1/13دطنا0[1 123180 التي سيتم البحث 


© معرفة رقم العمود :IndexOfDataSetColumn‏ 
تستقبل اسم العمود في مجموعة البيانات» وتعيد رقم الخانة التي يوجد بها كائن 
خريطة هذا العمود في القائمة إن وجدء أو تعيد ١-‏ إن لم توجد خريطة لهذا 
العمود. 


1۸ 


ا واجهة خر بطة العمود 
IColumnMapping Interface‏ 


تمتلك هذه الواجهة خاصيتين فقط تستخدمان لربط عمود من مجموعة البيانات» 
بالعمود الأصليء وهما: 


وج عمود المصدر :SourceColumn‏ 


ونج عمود مجموعة البيانات 64011111 122625: 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النار» وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


11۹ 


9 فة حريظة السود 
DataColumnMapping Class‏ 


هذه الفئة تمثل الواجهة ع1م1/]2مدتن1)01 والواجهة 1010262616» وهي 
ترسم خريطة الربط بين عمود مجموعة البيانات والعمود الأصلي. 
ولحدث إنشاء هذه الفئة صيغتان: 
-١‏ الأولى بدون معاملات. 
؟- والثانية لها معاملان نصيان» يستقبلان اسم العمود الأصلي واسم عمود 
مجموعة البيانات على الترتيب. 
وإضنافة إلى ما تكله من خضائصض» تمتلك هذه الفقة الوسيلة الوبحيكة الجديدة القالية: 


7# معرفة عمود البيانات :GetDataColumnBySchema۸Action‏ 
تعيد كائن عمود البيانات :17363000111 المطلوب تبعا للمعاملات التالية: 
- كائن جدول البيانات 1734213616 الذي يحتوي العمود.. لاحظ أن اسم 
العمود في الجدول تحدده الخاصية 12312561001111 الخاصة بخريطة 
- كائن النوع ممرآ الذي يمثل نوع بيانات العمود. 
- إحدى قيم المرقم 40110 ة1طعطء5ع1115510: تحدد ماذا سيحدث إن لم 
يوجد العمود في مخطط الجدول. 
وتوجد صيغة أخرى لهذه الوسيلة» وهي صيغة مشتركة 51260» لهذا تزيد 
بمعاملين على الصيغة السابقة» هما المعامل الأول والثاني» اللذان يستقبلان 
اسم العمود الأصلي واسم العمود في مجموعة البيانات على الترتيب. 


ولقد استخدمنا الكود التالي في المشروع Mapping‏ لإعادة تسمية الجدول 
وعمودية: 
Dim TM = DaAuthors.TableMappings.Add(‏ 
"Table", "Authors-Books'"")‏ 
("المؤلف"' TM.ColumnMappings.Add("Author'"",‏ 
("الكتاب'" TM.ColumnMappings.Add('Book"",‏ 


— 
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مصانع المزودات 2101165 "1 Provider‏ 


لعلك شعرت بالاستياء من وجود أكثر من نوع من نفس الكائن للتعامل مع مزودات 
اغ 
- كائنات الاتصال OleDbConnection Jn‏ و SqlConnection‏ 
و .OracleConnection‏ 
- كائنات الأمر مل OleDbCommand‏ و SqlCommand‏ 
ف .OracleCommand‏ 
- كائنات قراءة البيانات مثل OleDbDataReader‏ و SqlDataReader‏ 
و .OracleDataReader‏ 
- موصلات البيانات مثل OleDbDataAdapter‏ و SqIDataAdapter‏ 
و .OracleDataAdapter‏ 
فهذا يجعلك تكتب كودا مختلفا لكل نوع من أنواع قواعد البيانات» رغم أن 
الأككلافه يتخصن: فقط فى يبحمل تعريف الكائنات» ولیس فى فكو الكوة! 
ولقد قدمت دوت نت ٠١٠١-5‏ حلا لهذه المشكلة بإضافتين هامتين: 
-١‏ تعريف الفئات العامة في النطاق 2.10212.00121201مع55:56» مثل: 
- الفئة 17000026460 التي تشتق منها جميع كائنات الاتصال. 
- الفئة 7220تدطه1<50 التي تشتق منها جميع كائنات الأوامر. 
- الفئة 120103216201 التي تشتق منها كل قارئات البيانات. 
- الفئة :زع)1م 10103803 التي تشتق منها كل موصلات البيانات. 
هذا يجعل من الممكن استخدام الفئة الأم للتعامل مع أي نوع من أنواع 
الففات المشتقة منها (راجع مفهوم الففات الأساسية المجردة 
Abstract Base Classes‏ وتعدد الأسماء 111511م2019:201 في فصل 
الوراثة في كتاب "من الصفر إلى الاحتراف: فيجيوال بيزيك دوت نت"). 
۲- إضافة الفئتين DbProviderFactories‏ و DbProviderFactory‏ إلى 
النطاق 53:51612.10318.00171101»: لإمدادك بمصنع خاص بمزود 
البيانات الذي تريد التعامل معه؛ مما يكمل قدرتك على تعميم الكودء كما 
سنرى بعد قليل. 
وسنتعلم في هذا الفصل كيف نستخدم هاتين الإمكانيتين لكتابة كود واحد للتعامل مع 
أنواع مختلفة من قواعد البيانات» وسنستخدمه للتعامل مع قاعدة بيانات الكتب في 
كل من سيكويل سيرفر وآکسیس. 


۷۱ 


2 فئة مصانع المزودات DbProviderFactories Class‏ 


تعتبر هذه الففة مجرد مدخل لاستخدام الفئة ›DbProviderFactory‏ وهي لا 


5 # معرفة فنات المصانع :GetFactoryClasses‏ 
تعيد جدول بيانات 1(21312616» يحتوي على بيانات عن مصانع المزودات 
المتاحة على جهاز المستخدم.. ويمثل كل صف في هذا الجدول أحد 
المزودات» بينما تعرض الأعمدة تفاصيل هذا المزود.. وهذه الأعمدة هي: 


Name‏ اسم مزود البيانات. 
أوصف مختصر لمزود البيانات. 
١ 131121116‏ الاسم الثابت للمزودء والذي يمكنك استخدامه 
الحصو ل على اله الفا به 
Assembly‏ الاسم الكامل لمزود البيانات» وهو يحتوي على 
Quai fiedName‏ | التفاصيل الكافية عنه» مثل الإصدار والثقافة التي 


ويمكنك رؤية هذه التفاصيل بنفسك في المشروع ١10313210510615‏ فهو 
يعرض ناتج هذه الوسيلة في جدول عرض. 


© 19- معرفة المصنع 60]1'2)01-7: 
تعيد مصنع المزود :162107101121401 الذي يتيح لك التعامل مع مزود 
معن ..:ولهذه الوسيلة الصبيعكان التاليتات: 
-١‏ الصيغة الأو لى تستقبل الاسم الثابت للمزود .InvariantName‏ 
؟- والصيغة الثانية تستقبل صف البيانات 10212103597 الذي يحتوي على 
من الوسيلة .GetFactoryClasses‏ 
دعنا إذن نتعرف على الفئة .DbProviderFactory‏ 


4 فئة مصنع المزود DbProviderFactory Class‏ 


هذه الفئة أساسية مجردة تجب وراثتهاء وهي تمتلك العناصر اللازمة للتعامل مع 
مزود البيانات الذي خصصت للتعامل معه. 
وتمتلك هذه الفئة الخاصية التالية: 
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ع يمكلهإنشاء ع د د لمص د البيائنات 


:CanCreateDataSourceEnumerator 
تعيد 1516 إذا كان مصنع المزود يسمح باستخدام الففة‎ 
للمرور عبر كل خوادم البيانات المتاحة..‎ 101: 

وسنتعرف على هذه الفئة بعد قليل. 


كنا نفلك هذه الفقة الوسائل الكالية: 


اا 


إنشاء باني نص الاتصال :CreateConnectionString Builder‏ 
تعيد باني نص الاتصال من النوع العام «DbConnectionStringBuilder‏ 
لكنه يكون مخصصا للتعامل مع مزود البيانات الذي أنشأت المصنع الحالي 


إنشاء كائن اتصال :CreateConnection‏ 

تعيد كائن اتصال من النوع العام 1(6000111601101» لكنه يكون مخصصا 
للتعامل مع مزود البيانات الذي أنشأت المصنع الحالي للتعامل معه. 

لاحظ أن كائن الاتصال الذي ستحصل عليه غير مرتبط بأي نص اتصال» 
لهذا عليك وضع نص الاتصال في الخاصية ع002266110251110) الخاصة 
به قبل محاولة فتح الاتصال. 


إنشاء كائن أمر :CreateCommand‏ 
تعيد كائن أمر من النوع العام 1(50001:17180» لكنه يكون مخصصا للتعامل 
مع مزود البيانات الذي أنشأت المصنع الحالي للتعامل معه.. وأنت تعرف أنك 
تستطيع الحصول على قارئ البيانات من كائن الأمر باستدعاء الوسيلة 
.ExecuteReader‏ 
لاحظ أن كائن الأمر الذي ستحصل عليه ليس مرتبطا بأي اتصالء لهذا عليك 
ربطه بكائن الاتصال الذي حصلت عليه من الوسيلة «CreateConnection‏ 
وهو مافعلناه في الدالة CreateCommand‏ في المشروع Factories‏ 
كالتالي: 

Dim Command = Fac.CreateCommand 

Command.Connection = Cn 

ويمكنك أداء نفس وظيفة هذه الوسيلة« باستخدام الوسيلة CreateCommand‏ 
الخاصة بكائن الاتصالء وفي هذه الحالة ستختصر السطر الثاني من الكود 
السابق: 
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Dim Command = Cn.CreateCommand 


إنشاء معامل :CreateParameter‏ 

تعيد معاملا من النوع العام :وع)1(72212116: لكنه يكون مخصصا للتعامل 
مع مزود البيانات الذي أنشأت المصنع الحالي للتعامل معه. 

ويمكنك أداء نفس الوظيفة» باستخدام الوسيلة :وع]اع :ه0622 الخاصة 
بكائن الأمر. 


إنشاء موصل بيانات :CreateData Adapter‏ 
تعيد موصل بيانات من النوع العام «DbDataAdapter‏ لكنه يكون مخصصا 
للتعامل مع مزود البيانات الذي أنشأت المصنع الحالي للتعامل معه.. وقد 
استخدمنا هذه الوسيلة في الدالة 04116 في المشروع و1"3»10116 

كالتالي: 

Dim Table As New DataTable 
Dim Da = Fac.CreateDataAdapter 
Da.SelectCommand = Cmd 
Da.Fill(Table) 


إنشاء باني أوامر :CreateCommandBuilder‏ 
تعيد باني أوامر من النوع العام »Db€ommandBui]der‏ لكنه يكون 
مخصصا للتعامل مع مزود البيانات الذي أنشأت المصنع الحالي للتعامل معه. 


إنشاء عداد مصادر البيانات :CreateDataSourceEnumerator‏ 
تعيد عدد مصادر البيانات من الل وع العام 
51101 لكنه يكون مخصصا للتعامل مع مزود 
البيانات الذي أنشأت المصنع الحالي للتعامل معه.. لاحظ أن مزود سيكويل 
سيرفر هو الوحيد الذي يدعم هذه الإمكانيةء لأن ا البيانات الخاصة به 
تعمل على خادم» لهذا ستعيد هذه الوسيلة Nothing‏ إذا استخدمتها مع أي 
مزود بيانات اخر غير سيكويل سيرفر! 

ويمكنك أن تستخدم الخاصية CanCreateDataSourceEnumerator‏ أولا 
قبل استدعاء هذه الوسيلة» لتعرف إن كان المزود يدعم عداد المصادر أم لا. 


إنشاء تصريحج 1011و15حط١دء‏ 012612 : 
تعيد تصريحا من النوع العام »0deAccessPermissi0n‏ لكنه يكون 
مخصصا للتعامل مع مزود البيانات الذي أنشأت المصنع الحالي للتعامل 
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معه.. لاحذظ أن الففنة DBDataPermission‏ ترت الففة 
0< وننه تشتق فئات التصريح الخاصة بكل مزود 
بيانات مثل 1015510ء50101160162.. شرح هذه المواضيع خارج نطاق هذا 
الكتاب. 


وترث الفئات التالية الفئة :DbProviderFactory‏ 

.OdbcFactory Class -١ 

.OleDbFactory Class ؟-‎ 

.OracleClientFactory Class -Y 

.SqlClientFactory Class -“‏ 
ولا يوجد جديد في هذه الفئات يستحق شرحه»ء فهي تملك نفس وسائل الفئة الأ 
لكن مع فارق واحد: أنها تعيد أنواعا خاصة بكل مزودء بدلا من الأنواع العامة التي 
تعيد وسائل الفئة الأم. 


وخير طريقة لإدراك عبقرية مصانع المزودات» هي أن نعيد كتابة المشروع 
8 بطريقة عامة» تسمح بالتعامل مع أي مزود بيانات.. كما تذكرء فقد 
أنشأنا في هذا المشروع فئة اسمها MyDbConnector‏ تسهل علينا إجراء أي 
عملية على قواعد بيانات سيكويل سيرفر.. الآن حان الوقت لنعمم هذه الفئة» بحيث 
نستطيع استخدامها للتعامل مع باقي أنواع المزودات التي يدعها إطار العمل.. هذا 
هو ما فعلناه في المشروع ‘Factories‏ الذي هو نسخة طبق الأصل من المشروع 
sks‏ اء كنه يع رض على النموذج زري تحويل 
105 122010 ليستطيع المستخدم اختيار التعامل مع قاعدة بيانات آكسيس أو 
قاعدة بيانات سيكويل سيرفرء والرائع حقا أن كود الأزرار الموضوعة على 
النموذج ظل كما هو بدون تغيير» بفضل استخدام مصانع المزودات! 

لكننا بالطبع أجرينا بعض التغييرات الضرورية على كود الففة 
:6101 ففقد عرفنا فيها مرقما اسمه ۲۶ل ۷1ه۴۲» واستخدمناه في 
تعريف معامل ثان لحدث الإنشاء New‏ ليرسل المستخدم عند إنشاء نسخة من هذه 
الفئةة تصن الاتصبال ونوع المؤزؤد: الذي يزيد التعامل مجه 

كما عرفنا دالة اسمها عص »GetProviderNa‏ تستقبل قيمة المرقم ءإعل¡0vإ۴»›‏ 
رق المتمن التي ل ام ها اروف الث سحتله الس الوسنيلة 
Provider Factories.GetFactor‏ للحصول على مصنع المزود الذي يريد 
المستخدم التعامل معه.. بعد هذا يصير من السهل استخدام وسائل هذا المصنع 
للحصول على كائن الاتصال وكائن الأمر وموصل البيانات اللازمة للتعامل مع 
قاعدة البيانات. 
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ولو نظرت إلى كود الفئة 2419:1(500260101 في هذا المشروع» فستجد أن 
التعديلات التي أدخلناها طفيفة» لكن تأثيرها هائلء فقد صارت لدينا فئة عامة 
تستطيع أداء معظم ‏ إن لم يكن كل - الوظائف التي نريدها على أي نوع من أنواع 
قواعد البيانات» مما يتيح لك استخدامها في مشاريعك لتقليل الكود الذي تكتبه إلى 
أقل حد ممكن! 
لاحظ أننا نغير نوع قاعدة البيانات التي نتعامل معهاء في حدث تغير الاختيار 
280 الخاص بزري التحويل» وذلك بالكود البسيط التالي: 
If RdSql.Checked Then‏ 
DbBooks = New MyDbConnector(‏ 
My.Settings.BooksMdfConStr,‏ 
MyDbConnector.Providers.SqlServer)‏ 
Else‏ 
DbBooks = New MyDbConnector(‏ 
My.Settings.BooksMdbConStr,‏ 
MyDbConnector.Providers.OleDb)‏ 
End If‏ 
حيث 10080015 هو متغير معرف على مستوى النموذج» نضع فيه نسخة الفئة 
Connector‏ التي نستخدمها لتنفيذ وظائف الأزرار. 
لاحظ أيضا أن استخدام الزر "الكتب١"‏ لاستدعاء الإجراء المخزن» يستلزم منك 
أولا أن تستخدم المشروع 1116)ع 860655540160210 لإضافة الإجراء المخزن 
355 إلى قاعدة بيانات الكتب الخاصة باكسيس. 


الطبقات المتعددة 21-1161-5: 

لعل المشروع السابق يكشف لك أهمية تقسيم مشاريع قواعد البيانات إلى طبقات 
5 مستقلة عن بعضها.. هذا يسهل عليك تطوير أي طبقة دون تغيير أي 
شيء في الطبقات الأخرى.. فنحن هنا مثلا عدلنا كود الفئة MyDbConnector‏ 
دون أن نغير أي شيء تقريبا في الكود الذي يستخدمهاء وهي ميزة تتضح فوائدها 
الهائلة في المشاريع الضخمة:. التي تريد الاستفادة من التطويرات التي تحدث في 
تقنيات قواعد البيانات» دون إعادة كتابة الكود كله منذ البداية.. فلو أن هذه المشاريع 
فة إلى طيقات» فسيتخصين اتير عى فة الأتصبال يقاضخة المانات 
للاستفادة من التقنيات الجديدة بينما ستظل الطبقة التي تعرضص البيانات للمستخدم 
كماهي بدون تغيير يذكر. . وتسمى البرامج التي تستخدم هذا التنظيم باسم 
التطبيقفات متعمددة الطبقات Multi-Tier Applications‏ 
أو Applications‏ “11م وتسمى أيضا باسم التطبيقات الموزعة 


۷٦ 


Distributed Applications‏ لأنها مقسمة على أكثر من طبقة.. والشهير أن 
تكتب مشاريع قواعد على ثلاث طبقات: 
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طبقة البيانات :1161 10262: 

وهي الطبقة التي توجد فيها قاعدة البيانات بما فيها من جداول وعلاقات 
وإجراءات مخزنة» ومستخدمين وصلاحيات وقواعد سرية وحماية 
وصيانة وحفظ نسخ احتياطية من البيانات.. إلخ.. وفي الشركات الكبيرة 
يكون هناك موظفون مسئولون عن إدارة هذه الطبقة. 

طبقة التعامل مع البيانات :Data Access Tier‏ 

في هذه الطبقةء يوجد الكود الذي يتصل بقاعدة البيانات ويحضر النتائج 
منها.. والفئة :2/15:1(5001160101 هي مجرد مثال مبسط على هذه 
الطبقة» لكن دوت نت تمنحك إمكانيات أقوى لتصميم هذه الطبقة مثل 
مجموعة البيانات: محددة التو ع وموضلات الجداول: التي ستتغرف عليها في 
الفصل القادم» ومثل ر150-10-56001.آ وغير ذلك. 

وتمتاز هذه الطبقة بأنك تستطيع استخدامها في أكثر من مشروع» مما يوفر 
لك الرقت والحيد» كنا كتك تويز ها دون الحاحة إلى إقاذة كناينة 
المشاريع التي تعتمد عليها. 

:Data Display Tier طبقة عرض البيانات‎ 

في هذه الطبقة يوجد الكود الذي يعرض البيانات للمستخدم» والمفروض ألا 
يوجد في هذه الطبقة أي كود يتصل بقاعدة البيانات. 


وسنتعرف على التطبيقات متعددة الطبقات بإذن الله بصورة أشملء في الكتاب 


YY 


2 فئة عداد مصادر اليبانات 
DbDataSourceEnumerator Class‏ 





قنسةه اف ااا مجر اکن کے الان د س |8 الققية 
«SqlDataSourceEnumerator‏ لأن قواعد بيانات سيكويل سيرفر هي التي 
تعمل على خادم» سواء أكان خادما محليا 1.0021 أو بعيدا eا0صع‌‌۸.‏ 

وتتيح لك هذه الفئة الحصول على معلومات عن الخوادم المتوفرة حاليا على الشبكة 
التي يتصل بها جهاز العميل. 

وكمتلك هذه الفثة الوسيلة الوحيدة التالية: 


7# معرفة مصادر البيانات :GetD4)4S0u res‏ 
تعيد جدول بيانات 1(313:13116» يحتوي على صفوف فيها تفاصيل الخوادم 
المتاحة.. ويعرض هذا الجدول الأعمدة التالية: 


ServerName‏ | اسم خادم البيانات. 

6 + | اسم النسخة التي تعمل من الخادم.. لاحظ أن سيكويل 
سيرفر يتيح تشغيل أكثر من نسخة من الخادم. 
IsClustered‏ ع1 إذا كان الخادم جزءا من تجمع 01051617 من 
الخوادم. 


Version‏ إصدار الخادم. 


ريبكك اكد هذه الوسيلة ور 0 قائمة 0 ا المتاحة 

2 ل ا > E‏ 
على الشبكة. 

- ناتج هذه الوسيلة قد يختلف من مرة إلى أخرى» بسبب ظهور بعض 
الخوادم أو اختفائها! 

3 هذه الوسيلة قد لا تعيد كل الخوادم المتاحة فعلاء لهذا عليك أن تعرض 
للمستخدم مربع نص أيضاء ليكتب اسم الخادم بنفسه إذا لم يجده في 
القائمة. 

وقد استخدمنا هذه الوسيلة في المشروع DataProviders‏ لنعرض في 
الجدول السفلي» الخوادم المتاحة على المزود المحدد في الجدول العلوي» كما 
هو موضح في الصورة: 
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Odbc Data Provider .Net Framework Data Provider fq 
OleDb Data Provider .Net Framework Data Provider fq 


OracleClient Data Provider .Net Framework Data Provider fq 
SaqlClient Data Provider .Net Framework Data Provider fq 


Microsoft SQL Server Compact Data Provider | .NET Framework Data Provider 


الخوادم المتحة على هذا المزود: 
ServerName | InstanceNam| IsClustered | Version‏ |[ 


PC 











لفعل هذاء استخدمنا الحدث :هن بون الخاص بجدول العرضء وفيه 
استخدمنا رقم الصف للحصول على كائن صف البيانات 0W‏ 4۸اه المناظر 
لهفي جدول المزودات» وأرسلنا هذا الصف إلى الوسيلة 
1165.015 للحصول على مصنع مزود 
البيانات: 


Dim R = ThblIProviders.Rows(e.RowIndex) 

Dim Pf = DbProviderFactories.GetFactory(R) 

بعد هذا استخدمنا الوسيلة CanCreateData Source Enumerator‏ للتأكد من أن 

:5101 اللحصول على عداد الخوادم» ومنه حصلنا 

على الحدول الذى ري على قال هد اراد ا ك اا 
55 وعرضناه في جدول العرض: 


۷۹ 























If Pf.CanCreateDataSourceEnumerator Then 
Dim Se = Pf.CreateDataSourceEnumerator 
Dim TblServers = Se.GetDataSources 
DgServers.DataSource = ThlServers 
Else 
DgServers.DataSource = Nothing 
End If 
عند تجربة هذا البرنامج على جهازك» لن تظهر أية خوادم إلا عند اختيار‎ 
مزود سيكويل سيرفرء حيث سيظهر الخادم المحلي إع۷إعS 1.0021 المعرف‎ 
على جهازك (وهو يمتلك نفس اسم جهازك) وفي الغالب لن يظهر الخادم‎ 
الذي يعمل على هذا الخادم المحلي!‎ 5 


2 فئة عداد مصادر_بيانات سيكويل سير فر 
Class‏ 1,11111111:2601 50110212501112 


هذه الففة موجودة في النطاق 5375160.10218.501» وهي ترث الفئة 
.DbDataSourceEnumerator‏ 

وتتعامل هذه الفئة مع عداد مخصص للمرور عبر خوادم سيكويل سيرفر المتوفرة 
على الشبكة الحالية. 

وتملك هذه الفئة خاصية واحدة جديدة» وهي: 


5 ف النسخة ع125)220: 

تعيد نسخة جديدة من الفئة 5011034850111061717111112101: مما يغنيك عن 
استخدام مصنع المزود أولا للوصول إليها. 
والمشروع 5015617175 يريك كيف يمكن استخدام هذه الخاصية لعرض 
الخوادم المتوفرة على جهازكء وهو لا يحتاج لفعل هذاء إلا إلى هذا السطر 
الوحيد من الكود: 

DgServers.DataSource = 

SqIDataSourceEnumerator.Instance.GetDataSources 


YA. 


ط١‎ 


مجموعة البيانات 10212561 


مجموعة البيانات هي وعاء مصغر لقاعدة البيانات في برنامجك» يتيح لك أن تحمل 
في الذاكرة» بعض الجداول أو أجزاء منها (تبعا للاستعلام المستخدم) مع قدرتك 
إنشاء العلاقات بينها ووضع القيود عليهاء وبهذا يمكنك التعامل مع هذه البيانات 
على جهازك بعد قطع الاتصال مع الخادم. ٠ ٠‏ 
وتمتاز مجموعة البيانات بأنها عامةء فهي تستطيع التعامل مع أي نوع من أنواع 
قواعد البيانات» ويمكنها استيعاب الجداول دون أن يعنيها مصدرهاء بينما تترك 
مهمة التعامل مع مصدر البيانات لموصل البيانات وكائن الاتصال.. لهذا يوجد في 
دوت نت نوع واحد فقط من مجموعة البيانات» على عكس الكائنات التي تعرفنا 
عليها سابقاء والتي يوجد منه نوع خاص بكل مزود. 
وتستخدم مجموعة البيانات داخليا كود ۷1> لحفظ مخططات الجداول والأعمدة 
مجموعة البيانات إلى جهازك في صورة وثائق ر23411» ومن ثم إعادة تحميلها في 
مجموعة البيانات مرة أخرى لاحقا. 
وكما ذكرنا من قبل» تحتفظ مجموعة البيانات بنسختين من كل سجل: 

-١‏ النسخة الأصلية 1510ء17 01121081 التي تم تحميلها من قاعدة البيانات. 

-١‏ النسخة الحالية ١761510‏ tرعإإCu‏ التي تحتوي على السجل بعد حدوث 

تغييرات به. 

ويمتلك كل سجل الخاصية 12015186 التي توضح حالته» وهل دخلت عليه 
تغييرات وهل تم حفظ هذه التغييرات إلى قاعدة البيانات أم لا.. وبهذا التنظيم 
تستطيع مجموعة البيانات نقل التغييرات إلى قاعدة البيانات وتحديثهاء بالاعتماد 
البيانات أفضل من قارئ البيانات في الحالات التالية: 


۸۱1 


-١‏ إذا كان البرنامج يتعامل مع الكثير من الجداول والسجلات: ويستخدمها 
أكثر من مرة بدون ترتيب معين.. في هذه الحالة يكون المرور عبرها على 
ا باستخدام قارئ البيانات أمرا غير عملي. 
- إذا كان المطلوب عرض البيانات للمستخدم والسماح له بالتعامل معها 
Cy‏ 
البيانات لا يقوم بتحديث السجلات» فهو للقراءة فقط 

۳ اذا كانت ب دحتت ين ا وقبود متووضة عليهاء ومن 
20111 العلاقات و القيودء وهذا غير متوش فی قاری البيانات. 


لكن على الجانب الآخرء تعاني مجموعة البيانات من العيبين التاليين: 

-١‏ تعتبر مجموعة البيانات عبئا على ذاكرة الجهاز» لهذا يجب عليك تحميلها 
بأقل قدر ممكن تحتاجه من البيانات» ولا تضع فيها الجداول بكامل صفوفها 
بدون فائدة» وبدلا من هذا استخدم شرطا في جملة التحديد 515158001 
لتحصل على السجلات المطلوبة بالضبط. أيضاء لا تحمل من الجداول 
أعمدة لا يحتاجها المستخدم. 

؟- قد تسبب مجموعة البيانات مشاكل عند تحديث قاعدة البيانات» وذلك إذا 
كان مستخدمون آخرون قد غيروا قيم بعض السجلات في قاعدة البيانات 
أثناء قطع الاتصال وتعاملك معها في مجموعة البيانات» فيما يسمى 
بمشاكل التطابق 171018005 '002011116207.. وقد رأينا في الفصل 
السايق كف يمكن حل هذه المشكلة. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


TAY 


2 فئة مجموعة البيانات يووا 1221256214 


هذه الفئة توجد في النطاق 53562.10368 وهي تمثل واجهة مصدر القائمة 
S0urce‏ التي سنتعرف عليها لاحقا. 
ولحدث إنشاء هذه الفئة الصيغتان التاليتان: 
-١‏ الصيغة الأولى بدون معاملات. 
- الصيغة الثانية تستقبل معاملا نضياء يمثل اسم مجموعة البيانات» الذي 
سيستخدم عند حفظ مجموعة البيانات في ملف اM١×.‏ 


وت تمتلك هذه الفئة ١‏ لخصائص التالية: 


وخ اسم مجموعة البيانات 6107216 122125: 
تحدد اسم مجموعة البيانات» ليتم استخدامه كاسم لعنصر الوثيقة 1(006©11111©116 
Element‏ في كود ,5341 عند حفظ مجمو عة البيانات. 


وخ نطاق الاسم :Namespace‏ 
تحدد اسع النطاق الذى سيت كذقة خط مضوعة البياناك في کرد 


وجا البادئة :Pref¡×‏ 
تحدد البادئة التي ستستخدم لتمييز العناصر التي تنتمي إلى نطاق مجموعة 
البيانات.. هذا مفيد إذا كان ملف ,7232411 يحتوي على نطاق الاسم فيه أكثر من 
مجموعة بيانات» وتريد تمييز كل منها تحت نطاق فرعي خاص بها. 


ملحوظة: 

عند استخدام الوسيلتين 1دم1163036 و 2تعطء15من: 230 لتحميل 
البيانات أو المخطط في مجموعة البيانات» فإنهما تبحثان في ملف .7001/1 
عن نطاق الاسم الموضح في الخاصية ©1(034256]310» ومجوعة البيانات 
المميزة بالبادئة الموضحة في الخاصية »امإ فإذا لم تعثر في الملف عن 
مجموعة بيانات تحقق هذين الشرطينء لا يتم تحميل أي شيء من الملف. 








ويريك المشروع DataSetSample‏ مثالا على استخدام هذه الخصائص.. 
ستجد هذا الكود مثلا حدث تحميل النموذج: 

Ds.Namespace = "My Project" 

Ds.Prefix = "Authors-Books"" 


TAT 











Ds.DataSetName = "DsBooks" 

ويظهر تأثير هذه الخصائص عند ضغط الزر "حفظ المخطط في ملف"» حيث 

ستجد أسماء هذه الخصائص مستخدمة في تعريف مخطط مجموعة في الملف 
.C\DsBooksSchema.xml‏ 


حساسة لحالة الأحرف مvإ)زوومSميCa-‏ 
ا طت ية هذه الخاصبية وو[ مقر عات النقاز ةو ار ع 
8 حساسة لحالة الأحرف.. هذا يؤثر في نتائج الوسيلة 
11.5161 والخاصية 103180011111111.110165510.. والقيمة 
الافتراضية لهذه الخاصية هي ه1815. 
لاح ظ أن تغيير قيمة هذه الخاصيةء سيغير تلقائيا قيمة الخاصية 
©1157 الخاصة بكل جدول في مجموعة البيانات. 


اق المحل 16و0[ 
تقرأ أو تغير كائن معلومات الثقافة 160161710 ©» الذي يحتوي على تفاصيل 
ال الت ققدم لمقاركة وثزكيي الوص المرجودة في جداول مجبوعة 
البيانات. 
لاحظ أن تغيير قيمة هذه الخاصية»ء سيغير تلقائيا قيمة الخاصية 1.0021 
الخاصة بكل جدول في مجموعة البيانات. 


"قل فرض القيود ‘EnforceConstraints‏ 
إذا جعلت قيمة هذه الخاصية ٥ن1‏ (وهي القيمة الافتراضية)» فسيتم التأكد 
سن فة القييوه المفروضة على الخذاورل عند الجر اء عمابات التهدية 
والإدراج والحذف. 


57 فز توجد بها أخطاء :HasErrors‏ 
تعيد ع1 إذا كان أي من جداول مجموعة البيانات قد حدثت به أخطاء أثناء 
عملية التحديث.. ويمكنك فحص الخاصية 113515015 الخاصة بكل جدول 
لمعرفة الجدول الذي تسبب في الخطأ. 


TA 


7 فط الجداول و1216 : 


تعيد مجموعة جداول البيانات م10]ء1(3121261600116» التي تحتوي على 
كائنات الجداول واءعزا0 103431816 الموجودة في مجموعة البيانات.. 
ار او مره اتل فى ان الا 

مايعنيا هنا هو أنك تستطيع تحرير هذه المجموعة من خلال نافذة 
الخصائص.. فلو ضغطت زر الانتقال الموجود في خانة قيمة هذه الخاصية» 
فستظهر لك نافذة محرر مجموعة الجداول Table Collection Editor‏ كما 


هو موضح في الصورة: 


FTO ETT × 


(Collection) 
(Collection) 


50 
DataColuran [] 
Table1 
DataTable1 
True 


Friend 


False 
en-US 0 


Tablel Properties: 
E Data 


A (ApplicationSettings 


Cokumns 
Constraints 
DisplayExpression 
MinirmurmCapacity 
flamespace 
Prefix 
PrimalyKey 
TableName 

8 Design 
(Name) 
Generatelember 
Modifiers 

8 Misc 
CaseSensitire 
Locale 


Members: 


rel 


Add | 


في هذه النافذة يمكنك إضافة جداول جديد بضغط الزر ۸4ء ثم استخدام 


الخصائص الموجودة فى 


القسم الأيمن من النافذة لتغيير اسم هذا الجدول 


وطريقة عرضه والأعمدة الموجودة به.. وسنتعرف على هذه الخصائص 
بالتفصيل في القصل اللا 


YAo 


57 ف العلاقات وجر1+612)10: 


تعيد مجموعة علاقات البيانات eto‏ ]1ھ n٣‏ ati0اDataRe»‏ التي تحتوي 
على كائنات العلاقات واءعزا©0 123121561361052 الموجودة في مجموعة 
اللياناك ومز ف .على هذه المجمورعة لقص في النصيل اللا 

لاحظ أن مل مجموخة البواتات بالجدا ول و السات ل يكيف العاذفات بين 
الجداول تلقائيا إلى مجموعة العلاقات 613105.. لهذا عليك أن تضيف هذه 
العلاقات بنفسك إلى مجموعة العلاقات» سواء من الكود أو باستخدام نافذة 
المخطط کت نارف ا كما ييكتك إضبافة العلا قات ير ا ام 
خلال اة الخصائسن.. فلو ضغطت. زر الال الموحوه فى خانة فة هذه 
الكاضسييك فسستظيز: لمك دا مخ رر مجو الات 
Relations Collection Editor‏ كما هو موضح في الصورة: 


[Relations Collection Editor o Ek 


Members: Relation1 Properties: 





ا« 


اضغط الزر Add‏ لإضافة علاقة جديدة.. ستظهر نافذة إنشاء العلاقة لتسمح 
لك بتحديد الجدولين والأعمدة المشتركة في العلاقة كما تعلمنا من قبل.. وبعد 
أن تضغط ×0 لإغلاق نافذة العلاقة» ستظهر العلاقة في القائمة اليسرىء 
وتظهر خصائصها في القائمة اليمنى.. ولو أردت تغيير عناصر العلاقة › 
فاضغط الزر 1:01 لعرض نافذة العلاقة مرة أخرى. 
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فط مدير العرض الافتراضي :DefaultView Manager‏ 
تعيد كائن مدير عرض البيانات عع [06 ع8 17313171613122 الذي يتحكم 
في البيانات التي تعرضها مجموعة البيانات.. وسنتعرف على هذا الكائن 
ا 


7 ف الخصائص الإضافية :Extended Properties‏ 

تعيد مجمو عة الخصائص 270617001160110 التي تحتوي على 

الخصائص الإضافية التي تضيفها إلى مجموعة البيانات. 

والمجمو عة 20617001160110 ترث الجدول المختلط 2125142616: مما 

يتيح لك إضافة اسم الخاصية كمفتاح ره والقيمة التي تريد حفظها فيها 

كقيمة 172116. 

والمثال التالي يضيف إلى مجموعة البيانات خاصية إضافية تحتفظ باسم 

البرنامج الخاص بك» ثم يعرض قيمة هذه الخاصية في رسالة: 
Ds.ExtendedProperties.Add('"'ProgName'", "MyProg")‏ 

MsgBox(Ds.ExtendedProperties('ProgName")) 


وجا تنسيق التراسل :RemotingFormat‏ 
تحدد اقسق الذى سيتم به إرزسال البياداك من جهاق إلى خو عندما شال 
مجموعة البيانات مع برنامج يستخدم التحكم عن بعد ع10670110» وهي تأخذ 
إحدى قيمتي المرقم 10214ه"[5611211723610 التاليتين: 


اص>× إيتم إرسال البيانات في صورة نصوص 1 ..>™N‏ هذه هي القيمة 
الافتراضية. 
117 | يتم إرسال البيانات في صورة أرقام ثنائية 8108317.. هذا متاح 











لاحظ أن تغيير قيمة هذه الخاصية» يغير قيمة الخاصية RemotingFormat‏ 
الخاصة بكل جدول في مجموعة البيانات. 


]ا طريقة سلسلة المخطط 11211280:021/1006 161225 5: 
تحدة كق س التعامل مع مخطط البيانات عند دة مجفوعة يانات 
محددة النوع +ع1(2:825 0عم157.. والسلسلة 0 izatiاSeria:‏ هي تحويل 
محتويات كائن موجود في الذاكرة إلى بيانات يمكن حفظها في ملف أو 
إرسالها عبر الشبكة.. هذا يتيح لك الاحتفاظ بحالة الكائن بعد إغلاق البرنامج 
لاستعادتها مرة أخرى بعد إعادة تشغيله» أو إرسالها إلى جهاز آخر للتحكم في 
هذا الكائن عن بعد ع186200)1.. وسنتعرف على السلسلة Serialization‏ 


TAY 











والتحكم البعيد 116710118 بالتفصيل في كتاب خاص بالمواضيع المتقدمة في 
برمجة إطار العمل بإذن الله. 

وتأخذ هذه الخاصية إحدى قيمتي المرقم :SchemaSerializatioMode‏ 
3 اأ5إضافة مخطط البيانات ضمن عملية السلسلة.. هذه 
هي القيمة الافتراضية. 

ExcludeSchema‏ عدم إضافة مخطط البيانات ضمن عملية السلسلة مع 
تغيرت قيمها عن القيمة الافتراضية» وبهذا يتم تقليل 
حجم البيانات المسلسلة بشكل كبير.. لاحظ أن هذه 
القيمة لا تصاح إذا كانت مجموعة البيانات عادية 
(غير محددة النوع .(Un-typed DataSet‏ 


وسنتعرف على مجموعة البيانات محددة النوع لاحقا في هذا الفصل. 











كما تملك هذه الفنة الوسائل التالية: 


21# محو ترو»1): 
تمحو كل السجلات من كل جداول مجموعة البيانات» لكنها لا تمحو الجداول 
نفسهاء ولا العلاقات بينها.. لاحظ أن هذه الوسيلة ستسبب خطأ في البرنامج لو 


.XmlDataDocument 


7# تصفير )مم8 : 
تفرغ مجموعة البيانات من جميع محتوياتهاء بما في ذلك الجداول والعلاقات 
والقيود. 


:Clone نسخ‎ 4 


مجموعة بيانات جديدة وتعيد مرجعا إليها.. لكنها لا تنسخ أي سجلات. 


TAA 











©- نسخ بودره©: 


والسجلات أيضا) إلى مجموعة بيانات جديدة وتعيد مرجعا إليها. 


#ات معرفة التغيرات ومعرC!4€)ءG:‏ 
تعيد مجموعة بيانات جديدة» تحتوي جداولها على الصفوف التي تم تعديلها أو 
إضافتها أو حذفها منذ ملء مجموعة البيانات الأصلية» أو منذ آخر استدعاء 
للوسيلة وءعع10130مع8.00.. وتعيد هذه الوسيلة عمنط710 إذا لم تجد أية 
تغيرات في مجموعة البيانات. 
لاحظ أن هذه الوسيلة قد تضيف إلى مجموعة البيانات الجديدة بعض الصفوف 
التي لم تتغير بياناتهاء وذلك للمحافظة على صحة العلاقات والقيود بين 
الجداول» مما يتيح لك إعادة دمج مجموعة البيانات الجديدة بمجموعة البيانات 
الأصلية إذا أردت» دون حدوث أية أخطاء. 
وتوجد صيغة ثانية لهذه الوسيلة» تستقبل إحدى قيم المرقم »DataRowState‏ 
التي تمكنك من الحصول على السجلات التي حدث بها نوع محدد من التغيير 
دون سواه.. وهذه القيم هي: 


Detached‏ | السجلات 2018 الخاصة بأي جدولء أو أنه حذف للتو من 
مجموعة سجلات أحد الجداول. 
لم يتغير تتغير بيانات هذا السجل» منذ أن تمّ تحميله من قاعدة 
Unchanged‏ البيانات أو منذ آخر استدعاء للوسيلة .AcceptChanges‏ 
اف | هذاالسحل لابين مركو فى قاعقة الرانات: و ا ت 
4 إضافته كسجل جديد إلى مجموعة البيانات. 
ق ١ك‏ كدف هذا اسح مسق و ا 
Deleted‏ موجودا في قاعدة البيانات. 
معدل تم تعديل هذا السجل» ولكن لم يتم حفظ التعديلات في قاعدة 
Modified‏ | البيانات بعد. 


ويمكنك دمج أكثر من قيمة من قيم هذا المرقم معاء باستخدام المعامل 0۸. 











۸۹ 




















#ا- تم تغييرها و1386 11250: 


تعيد 16 إذا كانت مجموعة البيانات تحتوي على سجلات قد تم تعديلها أو 
إضافتها أو حذفهاء ولم تحفظ بعد في قاعدة البيانات. 
ويمكنك استخدام هذه الوسيلة في حدث اغلاق النموذج «FormClosing‏ 
دود المستخدم إن كان يريد حفظ البيانات قبل إغلاق البرنامج أم rs‏ 
في المشروع 4ع011560111(2125.. وقد استخدمنا هذه الوسيلة في الزر 
کک من قاعدة البيانات" ت" في المشروع «DataSetSample‏ لحفظ أية 
تغييرات قبل إعادة تحميل البيانات. 
وتوجد صيغة ثانية لهذه الوسيلة» تستقبل إحدى قيم المرقم DataRowState‏ 
التي تعرفنا عليها من قبل.. وتعيد هذه الصيغة 1516 إذا كانت مجموعة 
البيانات تحتوي على سجلات وقع عليها نوع التغيير المرسل كمعامل.. 
والجملة التالية تخبرك إن كانت هناك سجلات جديدة أضيفت إلى مجموعة 
البيانات أم لا: 
MsgBox(Ds.HasChanges(DataRowState.Added))‏ 


8 قبول التغييرات :Accep†C‌hange¢s‏ 


تجبر كل جداول مجموعة البيانات على استدعاء الوسيلة AcceptChanges‏ 
لاا 


0 رفض التغييرات 5چ ھ00۲ ej‏ : 


تجبر كل جداول مجمو عة البيانات على استدعاء الوسيلة RejectChanges‏ 
الخاصة بها 


إنشاء قارئ بيانات :CreateData Reader‏ 

تعيد قارئ بيانات الجداول 1ع123:3136161630» الذي يمكنك من خلاله 
المرور عبر سجلات كل جداول مجموعة البيانات. 

وتنشئ هذه الوسيلة مجموعة نتائج +5©1 151116 لكل جدول» بنفس ترتيب 
الجداول في مجموعة الجداول 1038561.126165» وإذا كان أحد الجداول 
وذلك للحفاظ على الترتيب.. ويمكنك الانتقال من قراءة سجلات جدول إلى 
سجلات الجدول التالي باستخدام الوسيلة 71612651116 الخاصة بقارئ 
البياتات كما تعلمتا من قبل 

وتوجد صيغة ثانية لهذه الوسيلة ت نتبع لك التحكم في ارايت النشائع» حيكت 
تستقبل مصفوفة جداول :1123 «DataTable‏ تحتوي على جداول مجموعة 


۹۰ 


البيانات التي تريد أن تقرأهاء مع ملاحظة أن الجدول الذي يظهر في هذه 
المصفوفة أولا سيعرض قارئ البيانات سجلاته أولا. 

ويريك الزر "إنشاء قارئ بيانات" كيف يمكنك استخدام هذه الوسيلة لعرض 
كل محتويات مجموعة البيانات في نافذة المخرجات .Output Window‏ 


2# تحميل 1,020: 
تتيح لك هذه الوسيلة استخدام قارئ البيانات 10323162061 لإضافة المزيد 
من السجلات إلى مجموعة البيانات.. ولهذه الوسيلة ثلاث صيغ: 
-١‏ الصيغة الأولى تستقبل ثلاثة معاملات: 
- معامل من نوع الواجهة 110331262061 يستقبل قارئ البيانات. 
- إحدى قيم المرقم LoadOption‏ التي تحدد ماذا سيحدث إذا كانت 
بعض السجلات موجودة سابقا في مجموعة البيانات» وهل سيتم 
تحديث النسخة الأصلية من السجل Original Version‏ أم 
النسخة الحالية 7761510 غمعن©).. وقد تعرفنا على هذا المرقم 
في الفصل السابق. 
- مصفوفة جداول 411286 ©1(3312616» تحتوي على بعض 
الجداول الموجودة في مجموعة الجداول 120362561.18165» ليتم 
ملؤها بالسجلات من قارئ البيانات» حيث ستوضع سجلات كل 
مجموعة من النتائج 165111561 في الجدول المناظر لها في 
الترتيب في المصفوفة. 
لاخ الضيقة الثائية همائلة للصبيقة السابقة إلا أن ماما الثالك قل 
مصفوفة نصية تحتوي على أسماء الجداول بدلا من كائنات الجداول. 
*ا. الضبيخة الكالثة تز يد يمعامل اناف غلى الصنيفة لوكي هذا النعامل 
يأتي في الموضع الثالث في ترتيب المعاملات» وهو مندوب 
Delegate‏ من النوع »۴1]ErrorEventHandler‏ وهو المندوب 
المستخدم في تعريف الحدث 1011111101 الخاص بموصل البيانات.. 
ويمكنك أن ترسل إلى هذا المندوب عنوان إجراء مناسبء ليتم 
استدعاؤه لو حدث خطأ عند إضافة أحد السجلات إلى مجموعة 
البيانات 
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ب دمج :Merge‏ 
تمزج بعض السجلات بسجلات مجموعة البيانات. . والمزج يعني أنّ السجلات 
الجديدة ستتم إضافتها إلى مجمو عه ة البيانات» أمّا السجلات الموجودة سابقاء 
فسيتم وضع السجلات المضافة بدلا منها.. وتتم مطابقة السجلات من خلال 
المفتاح الأساسي لكل منهاء لهذا يجب أن يحتوي جدول مجموعة البيانات على 
مفتاح أساسي» وإلا أدت عملية الدمج إلى تكرار نفس الصفوف مرتين. 
ولهذه الوديلة العديه من الصو 


بعض الصيغ ذات معامل واحدء يستقبل البيانات المراد مزجهاء سواء 
كانت قادمة من مجموعة بيانات غ1234856: أو جدول 1221818616 أو 
مصفوفة سجلات .DataRow Array‏ 

بعض الصيغ تزيد على الصيغ السابقة بمعامل ثان» إذا جعلته عںuإآ‏ 
فستحتفظ مجمو عه ة البيانات الأصليّة بالنسخة الحالية للسجلات» وسيثم 
المزج فقط على مستوى النسخة الأصلية... دعنا نفهم هذا بمثال 
صغير: افترض أن لدينا سجلا في مجموعة البيانات» فيه خانة قيمتها 
الأصلية »١‏ وقيمتها الحالية ؟.. نريد أن نمزج هذا السجل بسجل مماثل 
له لکن القيمة الأصلية لهذه الخانة فيه هي e۳‏ وقيمتها الحالية هي 5 
لو كانت قيمة هذا المعامل عمںإ1٠‏ فستصير القيمة الأصلية لهذه الخانة 
في مجموعة البيانات بعد المزج ۳ء لكن ستظل قيمتها الحالية ؟.. أما 
إذا جعلت قيمتها عو[ه۴» فستصير القيمة الأصلية لهذه الخانة في 
مجموعة البيانات بعد المزج »١‏ وقيمتها الحالية ..٤‏ الجدول التالي 


القيمة الأصلية | القيمة الحالية 
سجل مجموعة البيانات ١‏ ۲ 
السجل الممزوج ۳ ٤‏ 


(قيمة المعامل 1:16) 
(قيمة المعامل ع1215) 


لاحظ أن جعل هذا المعامل ع1٠‏ هو الطريقة الوحيدة التي تستطيع 
بها تغيير القيمة الأصلية دون تغيير القيمة الحالية» لأن صيغ الوسيلة 
tem‏ .022101 التي تتيح لك تحديد النسخة التي تتعامل معهاء قابلة 
للقراءة فقط ولا يمكن استخدامها للكتابة! 

وقداستخدمنا الوسيلة معام" في المشروع 
Concurrency‏ مرتين: 


۲ ۳ 
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- مرة في حدث ضغط القائمة الموضعية "أريد حفظ تعديلاتي", 
وقد أرسلنا إلى المعامل الثاني لهذه الوسيلة القيمة 16 لتغيير 
النسخة الأصلية للسجل المراد إعادة حفظه؛ مع الاحتفاظ 
بتغييرات المستخدم لحفظها في قاعدة البيانات. 

د اوإطرة فى حت شط القائية الموضعية لاء كا "رق 
أرسلنا إلى المعامل الثاني لهذه الوسيلة القيمة 1/3156 للتخلص 
من السجل القديم» ووضع السجل القادم من قاعدة البيانات بدلا 
منه (يشمل هذا النسخة الأصلية والنسخة الحالية للسجل). 

كى الضف تيد علد الخد الاه بمعامل ثالث تد رت الل 
,الاو جدية ركان در Na‏ ركنم وجرد 
بعض الجداول أو الأعمدة في مجموعة البيانات الحالية)» وهو يأخذ 
إحدى قيم المرقم )ع4 ةدمعطء3ع 1115510 التي تعرفنا عليها من 
قبل.. تذكر أن القيمة الافتراضية في الصيغ التي لا تستقبل هذا المعامل 
هي A‏ بمعنى إضافة الجداول والأعمدة اللازمة إلى مجموعة 
البيانات الحالية لاستقبال البيانات الجديدة من مجموعة البيانات 
المضافة. 
ولا يتم التحقق من صحة القيود ومنجإ†ئووه٣»‏ إلا بعد اكتمال عمليّة المزج.. 
فإذا كانت هناك سجلات تعارض القيود المفروضةء يحدث ما يلي: 
- ينطلق خطأ في البرنامج من النوع .ConstraintException‏ 
- توضع القيمة ع1”215 في الخاصية DataSet.EnforceConstraints‏ 
لإيقاف تطبيق القيود» وذلك حتى يمكن الاحتفاظ بالبيانات الممزوجة 
إلى أن ترى كيف تحل المشكلة. 
يوضع نص الخطأ في الخاصية 1201:1101 الخاصة بكل سجل 
يتعارض مع القيود المفروضة» لهذا عليك فحص هذه الأخطاء 
وإصلاحها بالطريقة المناسبة» قبل محاولة وضع القيمة 1506 في 
الخاصية 065زه5 1010106000 من جديد لتطبيق القيود. 
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تخمين المخطط :InferXm1ISchema‏ 
تقرأ كود M11‏ وتحاول استنتاج مخططات الجداول من بيانات السجلات 
الموجودة فيهاء وتحمل هذا المخطط في مجموعة البيانات.. ولهذه الوسيلة عدة 
صيغء كل منها لها معاملان: 
- المعامل الأول يحدد الملف الذي يوجد به كود ر5)7411: سواء كان ذلك 
في صورة مسار الملف» أو كائن مجرى بيانات «رزوع5» أو قارئ 
نصي «1extReader‏ أو "قارئ .XmlReader "XML‏ 
- المعامل الثاني يستقبل مصفوفة نصية» تحتوي على أسماء عناوين 
المواقع 171 التي تريد استبعادها عند استخلاص المخطط من الملف. 


الحصول على كود المخطط :GetXm1ISchema‏ 
تعيد نصا يحتوي على كود 11× الذي يمثل مخطط الجداول الموجودة في 
مجموعة البيانات. 


الحصول على الكود اصر×)ء6: 
تعيد نصا يحتوي على كود ]11> الذي يمثل البيانات الموجودة في مجموعة 
البيانات. 


كتابة كود المخطط :WriteXm1Schema‏ 

تحفظ كود ,7341 الذي يمثل مخطط جداول مجموعة البيانات» في الملف 
المرسل إليها كمعامل» سواء كان في صورة مسار الملف» أو كائن مجرى 
بيانات ر«رروعئ5: أو قارئ نصي «1extReader‏ أو "قارئ "XML‏ 
. 

وتوجد عدة صيغ لهذه الوسيلة تزيد على الصيغ السابقة بمعامل ثان من نوع 
المندوب (عہS†r1 ype,‏ +0025761161)01» وهو يستقبل عنوان أي دالة لها 
معامل من النوع 6م15 وتعيد ..String‏ هذا مفيد إذا كانت مجموعة البيانات 
لحري على عمو وكوابل مع قوع واناك يركب ١‏ يكن تحريده إلى كن 
مباشرة» وفي هذه الحالة يمكنك كتابة دالة مناسبة توضح كيف يمكن تحويل 
اانه إلى تصن» وز سلا الى هذا المعامل. 


كتابة الكود :WriteX]‏ 

مماثلة للوسيلة السابقةء إلا أنها تحفظ سجلات مجموعة البيانات في ملف 
..×M1‏ وهناك صيغة أخرى لهذه الوسيلةء لها معامل ثان من نوع المرقم 
10١1م‏ الذي يمتلك القيم التالية: 

8 | كتابة السجلات فقط بدون كتابة مخطط البيانات.. هذه 
هي القيمة الافتراضية. 








۹٤ 








8 | كتابة السجلات ومخطط البيانات معا في الملف. 

DiffGram‏ كتابة كل محتويات مجموعة البيانات في الملف. بما في 
ذلك النسخة الأصلية 0و۷ 091زع0 والحالية 
Current Version‏ لكل السجلات› حتى لو لم تتغير 
النسخة الحالية للسجل عن النسخة الأصلية. 











وقد استخدمنا هذه الوسيلة في الزر "حفظ البيانات في ملف" في ١‏ لمشر وع 
eإاetSamp Data‏ وأرسلنا إلى المعامل الثاني القيمة WriteSchema‏ 
لحفظ المخطط مع البيانات.. هذا يضمن لنا حفظ العلاقة بين الجدولين والقيود 
المفروضة عليهماء والمفاتيح الأساسية والفرعية. 


ملحوظة: 

إذا أردت حفظ السجلات التي تغيرت فقطهء فعليك استخدام الوسيلة 
65م للحصول على مجموعة بيانات جديدة بها 
السجلات التي تغيرت فقطء. واستخدام الوسيلة 1كع717 الخاصة بهذه 
المجموعة الجديدة لحفظ سجلاتها. 








#ذ> قراءة كود المخطط :ReadXım1Schema‏ 
ممائلة للوسيلة 7ع 1ع 715مك3ع7773 في معاملاتهاء ولكنها تقوم بالوظيفة 
العكسية» حيث تقرأ المخطط من ملف ,70111 وتحمّله في مجموعة البيانات.. 
لاحظ أن هذه الوسيلة قد تتسبب في حدوث أخطاء إذا كانت مجموعة البيانات 
تحتوي على مخطط بالفعل» لهذا عليك استدعاء الوسيلة DataSet. Reset‏ 
أولا لمحو كل بياناتها ومخططاتها أولاء قبل استدعاء الوسيلة 
.ReadXmlSchema‏ 


# قراءة الكود ابر ×44ءR:‏ 
مماثلة للوسيلة السابقةء إلا أنها تقرأ بيانات السجلات من ملف ,73241 وتحملها 
في مجموعة البيانات.. وهناك صيغة أخرى لهذه الوسيلةء لها معامل ثان من 
نوع المرقم 50711562021006 الذي يمتلك القيم التالية: 
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القيمة الافتراضية. 

قراءة السجلات» وقراءة المخطط إن وجد في الملف (يجب أن 
ترسل إلى المعامل الثاني للوسيلة ارم ×ع)]]W‏ القيمة 
WriteSchema‏ ليتم حفظ المخطط مع البيانات» وبالتالي 
يمكنلك قراءته). . وإذا كان بمجمو عة البيانات مخطط بالفعل» 
تتم إضافة الجداول الجديدة اليه لکن خطأ سيحدث لو كانت 
مجموعة البيانات تحتوي على جدول له نفس اسم جدول 
ويؤدي طلب قراءة المخطط من ملف يحتوي على البيانات 
فقطء. إلى عدم تحميل أي منهما في مجموعة البيانات! 

قراءة السجلات فقطء مع تجاهل أي مخطط موجود. 


تتجاهل أي مخطط في الملف» وتحاول استنتاج المخطط من 
البيانات.. ويحدث خطأ إذا كانت مجموعة البيانات تحتوي 
مماثلة للقيمة السابقةء إلا أنها تستنج نوع بيانات كل عمودء 
فإن فشلت تعتبر أن نوع العمود ع10ا5. 


تقرأ السجلات الأصلية والحالية من الملف» وذلك إذا كنت 
حفظتها فيه سابقا باستخدام القيمة صهإ51۴۴6.. وإذا كانت 
مجموعة البيانات تحتوي على سجلات بالفعل فستحتفظ بهاء 
وستضاف إليها السجلات الجديدة. 

استخدم هذه القيمة إذا كان الملف يحتوي على أجزاء من كود 
31 وليس كود وثيقة كاملة. 


وقد انتما هذه الؤسيلة في الزر "قزاءة البياتات من فلك" فى المشبروع 
ع1متطة 1515 وأرسلنا إلى المعامل الثاني القيمة ReadSchema‏ 
لقراءة المخطط مع البيانات.. هذا يضمن لنا إنشاء العلاقة بين الجدولين في 
مجموعة البيانات» لأن وظيفة البرنامج تحتاجها. 

لاحظ أن الوسيلة [دم307ع2 لا تستدعي الوسيلة وععمهط10معم0كى تلقائيا 
كما تفعل الوسيلة ۴|11 .)مول ۸هاه(» لهذا فإن السجلات التي يتم تحميلها 
في مجموعة البيانات ستعتبر سجلات جديدة 400600»: ولو ضغطت زر 
الحفظ في قاعدة البيانات» فسيتم إضافة كل هذه السجلات مره ة أخرى إلى 


جدول المؤلفين وجدول الكتب» وهذا سيجعل البيانات مكررة!. 


. ولحل هذه 


555 





























المشكلةء عليك استدعاء الوسيلة AcceptChanges‏ مباشرة بعد تحميل 
السجلات إلى مجموعة البيانات» وبهذا يتم اعتبار أنها لم تتغيرء ولا يتم حفظها 
في مجموعة البيانات. 

لكنك قد تريد اعتبار السجلات جديدة في بعض المواقفء وذلك إذا كنت تملك 
البيانات في ملف 1× وتريد إضافتها إلى قاعدة بيانات فارغة. 

وهناك ملاحظة بسيطة أخرى» وهي أن هذه الوسيلة لا يهمها امتداد الملف» 
بل يهمها فقط صحة محتوياته.. لهذا فقد أعطينا للملفات الخاصة بنا في 
المشروع 0115605010362564) الامتداد 194.» وهي امتداد من اختراعنا 
(اختصار للتعبير 1015026 ›)0ataSe)‏ وجعلنا مربع حوار فتح ملف لا 
يعرض سوى الملفات التي لها هذا الامتداد» وبهذا نضمن أن الملفات التي 
نحاول قراءتها سيكون لها الصيغة المناسبة لمجموعة البيانات» فملفات 20/11 
تستطيع حمل أي نوع من البيانات وبأي تنسيق» لكنها لن تكون جميعا صالحة 
للعرض في برنامجنا. 


وتمتلك مجموعة البيانات الحدث التالي: 


#۶ فشل الدمج :MergeFailed‏ 
ينطلق إذا فشلت عمليّة دمج بيانات جدولين باستخدام الوسيلة معإ16.. يحدث 
هذا مثلاء إذا كان العمود المستخدم كمفتاح أساسي في السجل القادم» مختلفا 
عن الود الت كمنتاج اتناس في السكل ال جرد محفرحة الاك 
والمعامل الثاني م لهذا الحدث من النوع ›MergeFailedEventArgs‏ وهو 














بن ٠‏ »1061 | تعيد كائن الجدول »12343181 الذي رفض عملية 
اتم 

١ #5‏ 111016مه0 | تعيد نصا يشرح سبب التعارض الذي أدى إلى فشل 
عملية الدمج. 


۹۷ 











أ المعالج السحري لإنشاء مجموعة البيانات 


Generate DataSet Wezard 


موصل بيانات إعامه ل۸ 1233 إلى صينية مكونات النموذج» واضبط خصائصه 
كما تعلمنا من قبل» ثم اضغطه بز الفأرة الأيمن» ومن القائمة الموضعيّة اضغط 
الأمر "إنتاج مجموعة البيانات" 10268564 66261216.. وستجد نفس الأمر في 
القائمة الرئيسيّة واو أعلى النافذة. 

سيظهر لك مربع حوار "إنتاج مجموعة البيانات" كما هو موضح بالصورة: 

في هذه النافذة يمكنك اختبار. إنشاء 22281 
مخبر عه يزاداك من Generate a dataset that includes he specified babies, ss‏ 
بيانات موجود سابقا في البرنامج» أو مهاد د عوموانا 
te1‏ لاحظ أنك تستطيع ا ا 
تخير هذا الاسم والأفضل ا | 1ق ا 
اسم أكثر تعبيرا عن وظيفة مجموعة ۰ 

البيانات. 

وتعرض لك النافذة قائمة بأسماء 





البيانات» ليمكنك اختيار إضافتها Add thie dataset to the designer.‏ 7 
جميعا إلى مجموعة البيانات أو حذف | | س 

ويوجد اختيار أسفل النافذة» يحدد إذا كنت تريد إضافة نسخة من مجموعة البيانات 
إلى النموذج أم لا 


بعد أن تحدد اختياراتك اضغط )0 لإغلاق النافذة.. سيؤدي هذا إلى ما يلي: 

- إضافة ملف اسمه 250. 123435611 إلى ملفات المشروع التي يعرضها 
متصفح المشاريع 1ع101م<1 50111102.. والامتداد 50 هو اختصار 
للتعبير "لغة تعريف المخطط" xm1 Schema Definition‏ لهذا لو 
فتحت هذا الملف من مجلد المشروع باستخدام برنامج 20م78106» فستجده 
(الجداول والأعمدة والعلاقات والقيود التي تحتويها).. أما لو نقرت هذا 
الملف مرتين بالفأرة في متصفح المشاريع» فستعرض لك دوت نت نافذة 
مصمم المخطط 1ع مع1(0»51 12عطن5: وستجد فيها رسما مبسطا يمثل 
الجداول والأعمدة الموجودة في المخطط كما هو موضح بالصورة: 


۹۸ 





+ |#|5ا- وزلن؟ اقنكلا +؟مومى 141 - 2دم نامع نام مقويرهل مذلا‎ 
File Edit View Project Build Debug Data Tools Test Window Help 
Ie Sad alê ialaAIS Sle Hr ua تان 31 جد رداوك نه‎ TT 
3 DataSet ج‎ EERE 
+ Polnter # WindowsApplica tid 
lb DataTable 8- a My Project 
٠ Query 
1s Relation 
19 TableAdapter' 
# General 


DataSet1.wb‏ له 

3 DataSet1 ,xsc 

3 DataSetl.xss 
Enumil,vb 
1- Form1,.vb 





إنشاء فئة خاصة اسمها 1٤٥5ه)ه(‏ ترث فئة مجمو عة البيانات 10325616 
و59. كود هذه الفئة يوضع في الملف «DataSet1.Designer.vb‏ 
والذي ستجده في العناصر الفرعية للمخطط 250. 1723125611 إذا عرضت 
تيل وا اق ال رو فط الد 
A11 9‏ 5101 الموجود أعلى متصفح المشاريع. 
وتسمى الففة DataSet]‏ بمجمورعة البيانات محددة النوع 
t€‏ 4ءمpر۲؛‏ وسنتعرف بعد قليل على معنى هذا المسمى وفائدته. 
إضافة مجموعة بيانات اسمها 1236256111 إلى صينية مكونات النموذج 
..€0mponent ray‏ هذه المجموعة هي نسخة معرفة من الفئة 
1 و وستجد جملة تعريفها في ملف خصائص النموذج كالتالي: 
1 كذ Friend WithEvents DataSet11‏ 
لاحظ أن الاسم الافتراضي 486111( يشير إلى أن هذه هي النسخة رقم 
١‏ من الفئة 13685611.. ولو كنت سميت مجموعة البيانات منذ البداية 
5 مثلاء لكان اسم هف الس خة هو 
DsAuthorBooks1‏ بدلا من 1 .DataSet1‏ 


1 


- ظهور أداة جديدة اسمها 1230856141 في أعلى صندوق الأدوات 
0101 تحت شريط خاص يحمل الاسم: 
ProjectName Components‏ 
حيث عررده11ع20[6 هو اسم المشروع. 
وبهذا تستطيع إضافة نسخ منها إلى النموذج بطريقة مرئية. 
والمشروع 157601102182561 يريك مثالا على هذا. 
دعنا نر ماذا فعلنا حتى هذه اللحظة.. من القائمة الرئيسيّة وه5› اضغط الأمر 
Preview Data‏ (ستجد هذا الأمر أيضا في القائمة الموضعيّة عند ضغط موصل 
البيانات في صينيّة المكوّنات بزر الفأرة الأيمن).. هذا الأمر سيفتح نافذة استعراض 
البيانات التالية: 


Select an object to preview: Parameters: 


[Form1.sqlDataadapter1 3 | Name | Type | Yalue 


Target DataSet: No parameters are defined مه‎ the selected object, 
[windowsApplicationt ,„DataSet1 3 ] 
Preview | 





Results: 


عصفور من الشرق توفيق الحكيم 


| كانت لنا أوطان فاروق جويدة 





Columns: 2 Rows: 3 Close | 
2 





أعلى يسار هذه النافذة» توجد قائمتان منسدلتان» تتيحان لك تحديد موصل البيانات 
ومجموعة البيانات التي تريد استعراض بياناتهماء وأعلى اليمين ستجد جدولا 
يعرض المعاملات التي تم تعريفها في أوامر التحديد والتحديث إن وجدت.. أما 
الجزء السفلي من النافذة» فيعرض السجلات الناتجة من تنفيذ أمر التحديد» وهو 
سيكون فارغة مبدئيّاء إلى أن تضغط الزر 2]65716. 











مجموعة البيانات محددة النوع 12262561 :Typed‏ 

رأينا كيف قامت دوت نت بإنشاء فئة اسمها 173256141 آليا اعتمادا على المخطط 
12511.50 . وتسمى هذه الفئة باسم مجموعة البيانات محددة النوع 
t€‏ 604م:19» وذلك لأنها تقوم بتعريف أنواع خاصة لجداول وصفوف 
مجموعة البيانات» وتسمح لك بالتعامل مع الجداول والأعمدة بأسمائها مباشرة.. 
رلك يحنت هذل نقوع هذه الفنة يتعريف العديد.من اناضرم ولو فقحت العلف 
5+٠‏ في المشروع 15706010212564 فستجد فيه تعريف 
الفئة 1(3425611» وستجد فيها العناصر التالية: 


-١ 


فة خاصة لكل ضيف في كل دول ف مجدوزغة البياقاك د الشات تحن 
أسماء على الصيغة سه >R‏ حيث × هو اسم الجدول. 
وترث فئة الصف فئة صف البيانات الأم 21034281201 وبداخل هذه الفئة يتم 
تعريف خاصية باسم كل عمود من أعمدة الجدول» تعيد قيمة الخانة الموجودة 
في هذا العمود في هذا الصف.. فمثلاء ستجد داخل الفئة 04486٤1‏ فئة 
اسمها 41101512037 تمثل صف البيانات في جدول المؤلفين» وستجد 
بداخلها خاصيتين هما: 41101 و 8001 تعيدان اسم المؤلف واسم الكتاب 
فاا الخال 
فئة لكل جدول موجود في مجمو عة البيانات.. هذه الفئات تحمل أسماء على 
الصيغة 21(0362312616» حيث × هو اسم الجدول. 
وترث فئات الجداول الفئة عامة النوع (1 6012361618256)014م157' والتي 
ترث بدورها فئة الجدول »1(342812616: حيث 1 هو نوع صفوف الجدول. 
فمثلاء ستجد داخل الفئة 1236256141 فئة اسمها AuthorsData Table‏ تمثل 
جدول المؤلفين» وهي ترث الفئة .TypedTableBase(Of AuthorsRow)‏ 
وبداخل فئة الجدول» يتم تعريف خصائص للتعامل مع كل عمود بالجدول» 
وهي تعيد كائنات من نوع فئة العمود 001355 1(313000111111.. فمثلاء ستجد 
في الجدول AuthorsData Table‏ الخاصيتين AuthorColumn‏ 
و 010 0okدB‏ اللتين تتيحان لك التعامل مع عمودي المؤلفين والكتب. 
كما يتم تعريف عدة أحداث لفئة الجدول إضافة إلى ما ترثه من الفئة 
›DataTable‏ وهي: 

- الصف يتغير .XRowChanging‏ 

- الصف تغير .XRowChanged‏ 

- الصف يُحذف .XRowDeleting‏ 

- الصف خذف .XRowDeleted‏ 
حيث × هو اسم الجدول.. فمثلا: في جدول المؤلفين يتم تعريف الأحداث 
التالايسية «AuthorsRowChanged ‘AuthorsRowChanging‏ 
.AuthorsRowDeleted «‘AuthorsRowDeleting‏ 


۲۰١ 


۳- عدة خصائص على مستوى الفئة 17389641 تحمل أسماء جداول مجموعة 
[لفوانات» افيد لك الحضول لى كان من نوع فة هذا التحذول. . فمخلاة 
ستجد في الفئة 102125611 خاصية اسمها 11]015رء تعيد نسخة من الفئة 
©1211 ويمكنك من خلالها التعامل مع جدول المؤلفين. 


لكن لماذا كل هذا؟.. وبم تفيدنا المجموعة محددة النوع يا ترى؟ 
انظر مثلا إلى الجملة التالية» التي تقرأ اسم المؤلف الموجود في الصف الثالث في 
جدول المؤلفين: 
DataSet11.Tables("Authors'"").Rows{2).Item("'Author"")‏ 
واضح طبعا أنها جملة طويلة تدفع إلى الاستياء.. فما رأيك إذن في الجملة التالية: 
DataSet11.Authors(2).Author‏ 
إن الجملتين كلتيهما - ويا للعجب - متكافئتان» وإن كانت الأولى عامّة تستخدم 
خصائص فئة مجموعة البيانات الأم وو6©'12 مه0 بينما الثانية خاصّة» 
تستخدم خصائص مجموعة البيانات 123435611 محددة النوع.. لاحظ أن الجملة 
الثانية تمنحك الميزات التالية: 

, _ مختصرة وواضحة ومفهومة.‎ -١ 

-١‏ أقل عرضة للخطأ.. ففي الجملة الأولى (الطويلة) هناك احتمالان للخطأء 
وذلك أثناء كتابتك لاسمي الجدول 115015كر والعمود إ0طاںAء‏ لأنك 
تكتبهما يدويا كنصوص» ولا يتم اكتشاف أي خطأ فيهما إلا أثناء تشغيل 
البرنامج.. أما في الجملة الثانية (القصيرة)ء فإنك تتعامل مع خصائص 
اة بمائقا في ا 1 6 ولن يقبل محرر الكود أي خطأ في 
أسمائهاء مما يعني انعدام أي فرصة ة للخطأ. 

۴ لا تحتاج عند كتابتها إلى تذكر أسماء الجداول والأعمدة بنفسك» وهو أمر 
تتضح أهميته في قواعد البيانات الضخمة التي تحتوي على عشرات 
الجداول» التي يحتوي كل منها على عشرات الأعمدة ممايعني أنك 
ستضيع الكثير من الوقت لو استخدمت مجمو عة بيانات عادية لأنك 
ستبطر :الى العو دة الى قاهدة البيانات كرا لتذكر أمنماء عنتاصر ها 
بينما مجموعة البيانات محددة النوع تجعل الحياة جنة» لأن الاستشعار 
الذكي 104111196056 سيعرض لك قائمة الأسماء بمجرد كتابة النقطة . 
لتختار منها اسم الجدول أو العمود الذي تريد التعامل معه. 

كل هذا يوضح لك فوائد مجموعة البيانات محددة النوع» وكيف تختصر وتسهل 
كتابة الكود بشكل كبير. 

والمشروع 103125610021615 يريك كيف يمكن عرض كل جداول وعلاقات 
وبيانات مجموعة البيانات محددة النوع» بالطريقة الموضحة في الصورة: 











أحمد خائد توفيق لم 





الآن تراه 


توفيق الحكيم ٠‏ 
: عرض الجداول 
ا 0 


عصفور من الشرق 00 
2 عباس العفاد ‏ | 


ْ عرض اليبانات | عرض العلاقات 





يمكنك استعارة مخطط ]11 من مشروع آخرء وإنشاء مجموعة بيانات محددة النوع 


بناء 


عليه.. لفعل هذاء اتبع الخطوات التالية: 


أنشئ مشروعا جديدا. 

من القائمة العلوية عع إ۴« اضغط الأمر .Add Existing Item‏ 

استخدم مربع حوار فتح ملف للوصل إلى مجلد المشروع «DataSetContents‏ 
واختر الملف 105/41110151300125.550.. سيضاف هذا الملف إلى المشروع. 
وفي مربع الحوار الذي سيظهر اختر 10242566 4ءمرآ.. ستجد أن القائمة 
المنسدلة تعرض العنصر 2.1(5/4111015130015» حيث × هو اسم المشروع.. 
اضغط >[0. 

ستضاف مجموعة بيانات اسمها51ع1 105811410151900 إلى صينية المكونات.. 
يمكنك استخدام نافذة الخصائص لتغيير اسمها إلى أي اسم مناسبء وليكن 105. 
اضغط هذه المجموعة بزر الفأرة الأيمن» ومن القائمة الموضعية اضغط الأمر 
..Edit[in DataSet Designer‏ سيؤدي هذا إلى فتح مخطط M۷1‏ وستجد 
فبدمخطط جدول الو لفن ومخطط حول الكنيه والحلاقة تيا 














إنشاء مجموعات بيانات خاصة :Custom DataSet‏ 

في هذا المقطع سننشئ مجموعات بيانات بدون تحميل أية تفاصيل من قاعدة 
البيانات.. سننشئها باستخدام مخطط ,1آ]223» وسنربطها بجدول عرض 
7167 بحيث يستطيع المستخدم إدخال البيانات بهاء وسنسمح له بحفظ 
هذه البيانات في ملف ۷11[ وإعادة تحميلها بعد ذلك كما يشاء. 

ابدأ مشروعا جديدا اسمه 0101540111(0218561» ومن القائمة الرئيسية )نع زمعم 
اضغط الأمر جررهغ1 72161 400 لعرض نافذة إضافة عنصر.. من القائمة اليسرى 
اختر العنصر 1032» ومن القائمة اليمنى اختر العنصر ]ع1(02]25» وحذد اسما لهذا 
العنصر الجديد وليكن 14ع141771(3635؛ واضغط الزرٌ >[0. 

سيضاف مخطط ,531 إلى المشروع اسمه 24910312561.550.. انقره مرتين 
بالفأرة لعرض مصمم المخطط. 

لو فتحت صندوق الأدوات الآن» فستجد به أدوات تناسب مخطط ,731» وستكون 
مبوبة تحت الشريط 12(3]2566.. انقر مرّتين بالفأرة على العنصر 1034812816 
لاضاقة جزل حديد إلى الط .هذا الول سط على الط ظط فى ضصوارة 
مستطيل فارغ» يحمل الاسم الافتراضي 11 لتغيّر هذا الاسم, اضغطه 
بالفأرة لإظهار مربع التحريرء واكتب الاسم الجديد كارع لں)؟ء ثم اضغط 
1. كما يمكنك استخدام نافذة الخصائص لتغيير اسم الجدول. 

ولإضافة عمود إلى هذا الجدول» اضغطه بزر الفأرة الأيمن» ومن القائمة 
الموضعية اضغط 400 شم 00111).. حرر الاسم الافتراضي للعمود الجديد» 
حل اة 10 (ضبغط 24 لعرهن ثافذة القصبائض :"و متكي كاه 
©1159 لجعله من النوع 1032.. ويمكنك استخدام باقي الخصائص للتحكم 
في العمود بالطريقة التي تناسبك.. مثلا: اجعل للخاصية 411012016176114 القيمة 
فرج لمعدل هذا لحفلل E E‏ إن تفل الاکن 
AutoIncrementSeed‏ و uto1ncrementStep‏ القيمة .١‏ 

اضغط الهامش الأيسر للعمود 17 بزر الفأرة الأيمن» ومن القائمة الموضعية 
اضغط الأمر Set Primary Key‏ لجعله المفتاح الأساسي. 

أضف إلى الجدول عمودا جديدا بنفس الطريقة واجعل اسمه عمصه".. سيكون نوع 
هذا العمود ع9 بصور افتراضية:؛ فاتركه كما هو.. يمكنك أن تحدد الخاصية 
11 في نافذة الخصائص وتجعل قيمتها 1506'» لتجعل اسم التلميذ متفردا غير 
قابل للتكرار.. ويمكنك أن تضع في الخاصية طاعرم[×ه"N‏ القيمة ١‏ لرفض أي 
اسم أطول من "١‏ حرفا. 

ولو أردت إدراج أي عمود قبل العمود عه" فاضغط هامشه الأيسر بزر الفأرة 
الأيمن» ومن القائمة الموضعية اضغط الأمر 0112© 105614.. وتستطيع حذف 
أي عمود في أي لحظة بتحديده وضغط الزر ع12616. 


بنفس الطريقة يمكنك إضافة جدول آخر اسمه «Subjects‏ فيه العمودان: (11 
و عمنةآ<.. لاحظ أنك تستطيع نسخ الجدول 56106045 باستخدام الآأمر 0603© 
ولصق نسخة جديدة منه باستخدام الأمر م†وه۴»› حيث سيأخذ الجدول الجديد الاسم 
1 والذي يمكنك تغييره إلى 5116[6015.. هذا يسهل عليك إنشاء 
الجداول المتشابهة في تركيبها. 
أضف جدولا تالثنا اسمه وع1200)» وأضف إليه الأعمدة StudentID‏ 
و SubjectID‏ و 613206.» ولا تنس أن تغير نوع بياناتها جميعا إلى 10416. 
واضح أننا سنسجل في الجدول و01206) درجات كل طالب في كل المواد.. هذه 
علاقة متعدد بمتعدد رمج 0-۷N)-رمه/۰‏ فالطالب مرتبط بكل الموادء والمادة 
مرتبطة بكل الطلاب.. هذه فرصة لنجرب التعامل مع هذه العلاقة. 
ويجب هنا أن نجعل الحقلين (560061411 و (5116[60111 معا زوجا متفرداء حتى 
لا نكرر درجة نفس التلميذ في نفس المادة.. لفعل هذاء حدد هذين الحقلين 
(بضغطهما بزر الفارة مع ضغط الزر Ctrl‏ من لوحة المفاتيح)» ثم انقرهما بزر 
الفأرة الأيمن» ومن القائمة الفرعية 400 اضغط رع.. ستظهر نافذة إضافة قيد 
التفرد 00511214 17010116 كما هو موضح في الصورة: 
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Name: 


Columns: 

vi 5600211110 

2 SubjectlD 
Grade 


' Primary key 





في مربع النص العلوي اكتب اسم القيدء وفي القائمة السفلية تأكد أنك اخترت 
الأعمدة التي سيتم تطبيق القيد عليها (ستجد العمودين 7[ عStud‏ 
و 51060611 مختارين فعلا لأنك حددتهما قبل فتح النافذة).. ولو أردت جعل 
هذين العمودين مفتاحا أساسيا للجدول أيضاء فضع علامة الاختيار أمام الاختيار 
Primary Key‏ أسفل النافذة.. لكننا لا نحتاج إلى هذا هنا.. اضغط 0O‏ لإنشاء قيد 
التفرد. 

نريد الآن أن ننشئ العلاقات بين هذه الجداول.. يمكنك نقر العنصر 106136402 
مرتين بالفأرة في صندوق الأدوات لعرض نافذة إنشاء العلاقة.. أو يمكنك أن 
تسحب العمود الأساسي من الجدول الرئيسيء وتسقطه على العمود الفرعي في 
الجدول التابع.. ولا تمر وأنت تسحب أي عمود على عمود آخر في نفس الجدول» 


ا 





وإلا فسيتم تحديده واعتباره جزءا من العلاقة.. لكنك تستطيع تصحيح ذلك في نافذة 
العلاقة على أي حال.. هذه النافذة مألوفة» ولن تجد فيها أي جديد لم نتعرف عليه 
سابقا. 
نريد هنا أن نربط بين العمودين (5600645.11 و (612065.560062411: وكذلك 
بين العمودين (15.11ء5116[6 و (411ع013065.5116[6.. ولا تنس المحافظة على 
Both Relation And Foreign Key Constraint‏ 
من القسم: موجن 10 what‏ 010056» على أن تجعل اختيارات الحذف والتحديث 
والرفض ع035030).. هذا سيريحنا من المشاكل التي تحدث عند حذف اسم طالب» 
أو تغيير اسم مادة» فالتكامل المرجعي سيحافظ على جدول الدرجات صحيحا دائما. 
بعد إنجاز هذاء يجب أن يبدو المخطط كالتالي: 


Grades‏ هآ 

"007 StudertID 

7 متاععرطت‎ 
ade 





ثريد الآن إنتاج مجموعة بياداث من هذا المخطط., لفعل هذا انتقل إلى النموذج: 
وافتح صندوق الأدوات وانقر مرتين على العنصر 1298966.. سيظهر لك مربّع 
صوار إكسافة مجموسة دات وستتجة فلي القائسة العلوية اسم الك 
51 . اضغط 0 لإنتاج مجموعة بيانات محددة النوع من هذا 
المخطط حيث ستضاف نسخة منها اسمها 743103185611 إلى صينية مكونات 
النموذج.. أقترح تغيير اسمها إلى .DsStudents‏ 

من هذه النقطةء يمكنك استخدام مجموعة البيانات بنفس الطريقة التي اعتدتها سابقاء 
وربطها بجدول العرضء وحفظ وتحميل البيانات بالطريقة المألوفة.. وستجد الكود 
الكامل الذي يفعل هذا في المشروع .CustomDataSet‏ 

لاحظ أن إجراء أي تعديل على مخطط ,3)3111: ينعكس مباشرة على فئة مجموعة 
البيانات محددة النوع؛ لهذا لست في حاجة إلى حذفها ثم إعادة إنشائهاء فكل شيء 
جرب مثلا إضافة عمود محسوب 0011© 03121112160 إلى الجدول 012065.. 
لفعل هذا افتح المخطط. واضغط الجدول 613065 بزر الفأرة الأيمن» ومن القائمة 


Î 


الموضعية اضغط الأمر 011" 105616.. سم العمود الجديد ٤م‏ زطاuا؟»‏ وفي 
نافذة الخصائص حدد الخاصية 165510م1 وضع فيها النص: 

Parent(Subjects Grades).Name 
القيمة عمuںإ]» وهذا معناه أن‎ ReadOnly بمجرد أن تفعل هذا ستصير للخاصية‎ 
المستخدم لا يستطيع تعديل قيم هذا العمود. لأنه سيعرض ناتجا محسوبا بناء على‎ 
قيمة عمود آخر.. وفي حالتنا هذه جعلنا هذا العمود يعرض اسم المادة الدراسية»‎ 
وذلك من خلال العلاقة 5116[6015_013065 التي تربط جدول المواد بجدول‎ 
قيمة الحقل الفر عي في هذه العلاقة‎ Subject الدرجات» حيث سيستخدم العمود‎ 
(وهو الحقل 12ء زطں5) ليحضر اسم المادة التي لها نفس الرقم من جدول‎ 
المواد.. وسنتعرف على الأعمدة المحسوبة بتفصيل أكثر في فصل الجداول.‎ 


الاسم 
ریف محمد 








تلاحظ كما هو واضح في الصورة:؛ إن إضافة اسم المادة إلى هذا الجدول سيجعلها 
تظهر في النافذة التي تعرض درجات الطالب» وهذا أفضل من إرباك المستخدم 
بعرض رقم المادة» والدرجة التي حصل عليها الطالب فيها. 

لاحظ أننا استخدمنا قائمة عج1.15620 لعرض أسماء الطلبة.. هذا يريح المستخدم 
أثناء إدخاله لدرجات الطلب» بسبب سرعة الاتثقال من طالب إلى آخر. 

ولعلك تتساءل: لم لا يدخل المستخدم أسماء الطلبة ودرجاتهم في نفس النموذج؟ 
الطالب كاملة وليس اسمه فقطء. مثل عمره» وفصله الدراسي» وعنوانه» وهاتفه... 
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إلخ.. وكل هذا يحتاج إلى مساحة عرض كبيرة» والأفضل عمل نموذج مستقل له» 
وهو ما فعلناه في هذا المشروع. ليمكنك البناء عليه فيما بعد. 

إلى الآن كل شيء رائع.. لكن تتبقى مشكلة في هذا البرنامج» وهي أن العمود 
المحسوب Subject‏ سيتم حفظه في الملف عند حفظ مجموعة البيانات» وهو ما 
سيزيد من حجم الملف بلا ضرورة.. لهذا علينا حذف هذا العمود من مجموعة 
البيانات قبل حفظها.. لكن هذا سيؤدي إلى حدوث أخطاء في البرنامج! 

ويمكن حل هذه المشكلة؛ باستخدام الوسيلة رمه (45٥1.٣‏ لنسخ مجموعة 
البيانات إلى مجموعة بيانات احتياطية؛ ثم حذف العمود {ءعزاuا؟‏ من هذه 
المجموعة الاحتياطية» وحفظها بياناتها في الملف.. وبهذا تظل مجموعة البيانات 
الأصلية كما هي» بينما نحصل على ملف أصغر حجما.. وعند تحميل هذا الملف» 
لن تحدث أية مشكلة في البرنامج بسبب غياب العمود 0]6ع[5906» فهو عمود 
محسوب» وسيستنتج البرنامج قيمته.. وستجد الكود الذي ينفذ هذا في الزر 
"حفظ البيانات". 

لاحظ أن عيب هذه الطريقة هو أن نسخ مجموعة البيانات بكاملها قد يكون كارثة 
على الذاكرة إذا كان حجم بياناتها ضخما.. لهذا يمكن اللجوء إلى حل بديل» وهو 
حذف العمود من مجموعة البيانات قبل حفظهاء ثم إنشائه مرة أخرى بعد الحفظ 
مباشرة.. أسهل طريقة لفعل هذا هي الاحتفاظ بمرجع للعمود في متغير من النوع 
0011130 قبل حذفه من مجموعة أعمدة الجدول» ومن ثم حفظ البيانات في 
الملف» ثم إضافة العمود الذي نحتفظ بمرجعه إلى مجموعة الأعمدة مرة أخرى.. 
وستجد الكود الذي يفعل هذا في الزر "حفظ البيانات ؟". 


حفظ بيانات الشجرة في مجموعة البيانات: 

في المشروع ]401154011103856 رأينا مثالا على علاقة متعدد بمتعدد.. لعله 
يكون مناسبا الآن أن نرى مثالا على العلاقة الذاتية 56141:619610.. لفعل هذاء 
سننشئ مشروعا اسمه و171006عع535615» وهو يعرض شجرة ويتيح للمستخدم 
إضافة العناصر إليهاء وتغيير مستوياتهاء وهي وظائف تعلمنا كيف ننشئها في 
المشروع 16م116617167750 في كتاب برمجة الويندوز» ولن نكرر شرحها 
هنا.. وستجد المشروع 53761566110065 ضمن أمثلة هذا الكتاب. 

ما نريده الآن» هو أن نسمح للمستخدم بحفظ فروع الشجرة.. ونظراء لأنه من غير 
العملى اتشباء قاعدة يداناك كاملة لحف كن عناصين الجر ةة فسيكرى من الى 
هنا أن ننشى: مجموعة بياناث خاصة» ونستخذمها لحفظ العناصر فى ملف .3]/1.. 
ودا نكون قد اسنفدنا من قدرات مجموعة البياتات و غلذقاتهاء وف نفس الوقت 
سنحفظ البيانات في ملف مستقل. ۰ 

لفعل هذاء أضفنا إلى المشر وع SaveTreeNodes‏ مخطط مجموعة بيانات 
بالطريقة المالوفة»ء وأسميناه +ع175661(285؛: وأض فنا إليه جدولا اسمه 
5 ع1 »: وأضفنا إليه الأعمدة التالية: 


اسم العمود | نوع بياناته وظيفته 


Sig Text‏ يحفظ نص فرع الشجرة. 
المفتاح اأ ¢ 7 | قم الف لر د 
gı | t16 | ParentID‏ کک وهو يشير إلى رقم الفرع الرئيسي 


وقد أضفنا علاقة إلى مخطط الجدول» لتربط بين الحقلين 15 ر (23161611. 
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وقد أضفنا إلى النموذج نسخة من مجموعة البيانات وأسميناها و(15661.. وحتى لا 
نعقد الأمور على أنفسناء لن نملأ مجموعة البيانات بعناصر الشجرة إلا عند ضغط 
هو كود هذا الزر: 
TreeDs.Clear( )‏ 
For Each Node As TreeNode In TreeView1.Nodes‏ 
Dim R = TreeDs.TreeNodes.AddTreeNodes Row(‏ 
Node.Text, Nothing)‏ 
SaveChildren(Node, R)‏ 
Next‏ 
IreeDs. WriteXml("C: ecole: Sl‏ 
لإضافتها إلى الول ع ال في مجوعة 3 البيانات. اط 0 
مجموعة البيانات محددة النوع قد أضافت الوسيلة 20011 إلى 
الجدول» لتتيح لنا إضافة صف جديد إليه.. هذه الوسيلة تستقبل معاملين: 
- نصا يمثل قيمة الحقل ع1 في الصف الجديد. 
- كائن صف من النوع ›1reeDataSet.TreeNodesRow‏ لترسل إليه 
الصف الرئيسي للصف الحالي.. هذا أسهل من أن تضع بنفسك رقم الصف 
الرئيسي في الحقل (1])معترج» وهذه إحدى التسهيلات التي منحتها لك 
العلاقة الذاتية. . ونظرا لأن جذور الشجرة ة ليست لها فروع رئيسية» 
فسنرسل القيمة عمنط)ه<7 إلى هذا المعامل.. هذا سيترك الحقل 
Pa rnD‏ فار غا. 
بعد هذاء يجب أن نضيف إلى مجموعة البيانات فروع كل جذر.. لفعل هذا 
استخدمنا إجراء اسمه جزع5237:600110112»: وهو يستقبل معاملين: 
- كائن الفرع 11561006 الذي سنضيف عناصره الفرعية إلى مجموعة 
البيانات. 
- كائن الصف ow‏ reeDataSet.TreeNodesRا‏ الذي يعمل كصف 
رئيسي» للصفوف التي سنضيفها الجدول. 
هذا هو كود هذا الإجراء مع ملاحظة أنه إجراء ارتدادي 517 يستدعي 
نفسه» لأن كل فرع قد يحتوي على عناصر فرعية» كل منها قد يحتوي على 
عناصر فرعيةء وهكذا: 
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Sub SaveChildren(ByVal ParentNode As TreeNode, 
ByVal ParentRow As TreeDataSet.TreeNodesRow) 
For Each Node As TreeNode In ParentNode.Nodes 
Dim R = TreeDs.TreeNodes.AddTreeNodes Row( 
Node.Text, ParentRow) 
SaveChildren(Node, R) 
Next 
End Sub 
وبعد وضع جميع بيانات الفروع في مجموعة البيانات» سيتم تنفيذ آخر سطر في‎ 
كود ضغط زر الحفظء وهو يستدعي الوسيلة 17171167341 لحفظ محتويات‎ 
مجموعة البيانات في الملف.‎ 
وهكذا نكون قد حفظنا فروع الشجرة بالكامل.. بقي إذن أن نعيد قراءتها من الملف‎ 
عند ضغط زر التحميل.. لفعل هذا سنفرغ كلا من مجموعة البيانات والشجرة من‎ 
:10680700/1 محتوياتهماء ثم نقرأ بيانات الملف باستخدام الوسيلة‎ 
TreeDs.Clear( ) 
TreeView1.Nodes.Clear( ) 
TreeDs.ReadXml("'C:\TreeNodes.XmI!I") 
تعد هذا نفل البياكات من مجموعة البيانات إلى الشهرة .. لفحل هذا ستصيف‎ 
الجذور إلى الشجرة أولا.. نحن نعرف أن الجذر ممثل في الجدول بصف توجد في‎ 
الخانة (4611مع231 الخاصة به القيمة 1(6171111.. لهذا سنمر على كل الصفوف».‎ 
ونستخدم الوسيلة الجاهزة 152311411011111 التي عرفتها لنا مجموعة البيانات‎ 
محددة النوع» لنرى إن كانت هذه الخانة فارغة فان كانت كذلك» عرفنا فرعا‎ 
وأضفناه إلى الشجرة كجذرء‎ »1٠×) جديداء ووضعنا فيه النص الموجود في الخانة‎ 
ثم نستدعي الإجراء 1,0300110 لتحميل العناصر الفرعية في هذا الجذر..‎ 
هذا هو الكود الذي يفعل هذا:‎ 
For Each R In TreeDs.TreeNodes 
If R.IsParentI[DNull Then 
Dim Node = TreeView1.Nodes.Add(R.Text) 
LoadChildren(Node, R) 
End If 
Next 
أيضاء يجب أن يكون الإجراء ٣1ط 1,030 ارتداديا 12601115176 يستدعي‎ 
نفسه؛ لتحميل العناصر الفرعية لكل فرع في جميع المستويات.‎ 
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ولكن كيف نعرف العناصر الفرعية؟ 

هذا سهل جداء بفضل العلاقة الذاتية المعرفة في الجدول؛ فنحن نستطيع استخدام 
الوسيلة 0660111019015 لمعرفة الصفوف الفرعية التابعة لأي صف رئيسي.. 
هذا هو كود هذا الإجراء: 5 


Sub LoadChildren(ByVal ParentNode As TreeNode, 
ByVal ParentRow As TreeDataSet.TreeNodesRow) 
For Each R As TreeDataSet.TreeNodesRow In 
ParentRow.GetChildRows('Self Relation") 
Dim Node = ParentNode.Nodes.Add(R.Text) 


LoadChildren(Node, R) 
Next 
End Sub 


هذا هو كل شيء.. يمكنك الآن تجربة البرنامج» وإضافة العناصر إلى الشجرة 
وحفظهاء ثم استرجاعها في أي وقت. 
رائعة هي العلاقة الذاتية؟.. أليس كذلك؟ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النار» وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


YY 


4 فئة موصل الجدول TableAdapter Class‏ 


البيانات محددة النوع #عمع زوء(1 DataSet‏ 0م1577 بإنشائها في برنامجك لتسهيل 
تعاملك مع قواعد البيانات. 
ويشبه موصل الجدول 1ع1م401ء101' موصل البيانات ۲مم 1238803 في كل 
شيء» فهو يسمح لك بالحصول على السجلات من قاعدة البيانات لملء أحد جداول 
كبير من استعلامات التحديد 5181101 للحصول على سجلات الجدول بطرق 
مختلفة من قاعدة البيانات» بشرط أن يكون الناتج ملائما لتركيب الجدول الذي يتم 
ملؤه.. بينما موصل البيانات مهيأ للتعامل مع استعلام واحد فقط. 
ولكي تنشئ موصل جدول» يجب أن يحتوي برنامجك على مجموعة بيانات محددة 
التو اد . اتبع هذه الخطوات: 
أنشئ مشرو عا جديدا اسمه ءام Ada‏ ab1eا.‏ 
- من القائمة العلوية عع ز2:0 اضغط الأمر .Add New Item‏ 
251 وامنحها الاسم .DsAuthorsBooks.xsd‏ 
- في نافذة المخطط > افتح صندوق الأدوات» واسحب العنصر 
TableAdapter‏ وأسقطه علي مصمم المخطط. . سيؤدي هذا إلى بدء 
المعالج السحري لتهيئة موصل الجدول: 
TableAdapter Configuration wizard.‏ 
- أول نافذة في هذا المعالج» هي نافذة اختيار قاعدة البيانات المراد الاتصال 
بهاء وقد تعرفنا عليها من قبل.. اختر قاعدة بيانات الكتب 1800125.1701 
من الاتصالات المتاحة» أو أنشئ اتصالا جديدا بهاء ثم اضغط الزر ×ه. 
- النافذة التالية ستسألك إن كنت تريد حفظ نص الاتصال في إعدادات 
البرنامج.. وافق على هذ ودع الاسم الافتراضي 
1+ كما «ga‏ واضغط .Next‏ 
- النافذة التالية تتيح لك اختيار نوع أمر التحديد.. اختر 
Use SQL Statement‏ واضغط .Next‏ 
- في النافذة التالية اكتب استعلام التحديد التالي: 
SELECT * FROM Authors‏ 
واضغط ×عN.‏ 
- في النافذة التالية يمكنك اختيار الوسائل التي ستضاف إلى فئة موصل 
الجدول» كما هو موضح في الصورة: 
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TableAdapter Configuration ¥¢izard اا‎ 


Choose كلمطغع1؟]‎ to Generate 1 < اا‎ 
1 
” 


The TableAdapter methods load and save data between your application and the 
database, 


Which methods do you want to add to the TableAdapter? 
IV Fill a DataTable 


Creates a method that takes a DataTable or DataSet as a parameter and executes the SQL statement or 
SELECT stored procedure entered on the previous page. 


Method name: | 


IV Return a DataTable 


Creates a method that returns a new DataTable filled with the results of the SQL statement or SELECT stored 
procedure entered on the previous page, 


Method name: jGetData 


IV Create methods to send updates directly to the database (GenerateDBDirectMethods) 


Creates Insert, Update, and Delete methods that can be called to send individual row changes directly to the 
database, 


< Previous | Next > مع |ا‎ Cancel ۶ 
و‎ 





يمكنك أن تختار إنشاء وسيلة لملء جدول موجود في مجموعة البيانات» 
وسيكون اسمها المبدئي 1111 ويمكنك كتابة أي اسم آخر في مربع النص. 
كما يمكنك أن تختار إنشاء وسيلة تعيد جدول بيانات 1031812616 مملوء 
بالنتائج» لتستخدمه أنت بالطريقة التي تناسبك» وسيكون اسم هذه الوسيلة 
مبدئيا 061102 ويمكنك كتابة أي اسم آخر في مربع النص. 
أما الاختيار الأخيرء فيجعل موصل الجدول ينشئ الوسائل اللازمة لتحديث 
قاعدة البيانات.. هذه الوسائل ستحمل الأسماء Update‏ 
و Insert‏ و .Delete‏ 
بعد أن تحدد الاختيارات التى تناسبك» اضغط Nex‏ . 
- ستظهر نافذة تلخص اختياراتك.. اضغط 1151 لإنهاء المعالج السحري 
وإنشاء موصل الجدول. 
الموضح في الصورة.. هذا العنصر يمثل 8 
مخطط الجدول 11015ىمء» وفي الجزء ID‏ 
السفلي منه مخطط موصل الجدول الذي Author‏ 
سيستخدم للتعامل معه» واسمه الافتراضي CountryID‏ 
Phone .AuthorsTable Adapter‏ 





About 
RowVersion 
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24 Fill, GetData () 
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ويمكنك ضغط الشريط الذي يعرض اسم موصل الجدول بزر الفأرة الأيمن» 
واختيار الأمر و1016عم2:0 لعرض خصائص موصل الجدول في نافذة 
الخصائص.. و هده الخصائص هي: 


وخ الاسم :Name‏ 
تحدد اسم فئة موصل الجدول. 


ونج المجال :Modifier‏ 
تحدد مجال فئة الجدول.. والقيمة الافتراضية هي اطا" ليمكن استخدام هذه 
الف حى من خارج المشروع الحالي. 


وخ الفئة الام 1255© 13256: 
تحدد الفئة الأم التي ترثها فئة موصل الجدول.. في الوضع الافتراضي تكون 
هذه الفئة هي فئة المكون ..System.ComponentMode1l.Component‏ 
لكن لا مانع من أن تكتب بدلا منها أية فئة أخرى بشرط أن تكون مشتقة من 
الفئة ..Component‏ يمكنك مثلا أن ترث فئة موصل البيانات» أو يمكنلك أن 
ترث فئة موصل جدول آخر ! 


أو الاتصال :Connection‏ 
تحدد الاتصال بقاعدة البيانات.. ويمكنك اختيار اتصال من القائمة المنسدلة» أو 
ضغط العنصر الأخير فيها (14101ع00226) New‏ لإنشاء اتصال جديد. 


"و مجال الاتصال -ConnectionModifier‏ 
تحدد مجال كائن الاتصال المعرف في موصل الجدول.. والقيمة الافتراضية 
هي 110 لجعله مرئيا من أي موضع في المشروع. 

"و أمر التحديد -SelectCom mand‏ 
أمر التحديد المستخدم لإحضار البيانات من قاعدة البيانات.. لاحظ أنك لو 
استخدمت أمر تحديد يعيد بيانات من أكثر من جدول» فسيعجز موصل الجدول 
عن إنتاج أوامر التحديث والإدراج والحذف آلياء لهذا يتوجب عليك في هذه 
الحالة استخدام الخصائص التالية لتعريف هذه الأوامر بنفسك. 


وخ أمر التحديث 031212110 012166م11: 
أمر التحديث المستخدم لتحديث سجلات قاعدة البيانات. 


وخ أمر الإدراج :InsertCommand‏ 


1° 


أمر الإدراج المستخدم لإدراج السجالات في قاعدة البيانات. 


وجا أمر الحذف :DeleteCom mand‏ 


أمر الحذف المستخدم لحذف السجلات من قاعدة البيانات. 


وخا إنتاج وسائل قاعدة البيانات المباشرة :GenerateDb Direct Methods‏ 


إذا کلت شبة هذ الا عن نياف الى ها ول الول 
الوسائل 17009246 و 105616 و 1261016 لتتيح لك تحديث قاعدة البيانات 
باستدعائها مباشرة.. أما إذا جعلتها 213156 فسيكون عليك استخدام كائنات 
الأوامر بنفسك لإجراء عمليات التحديث والإدراج والحذف» وذلك من خلال 
الخصائص .DeleteCommand <‘InsertCommand ‘UpdateCom mand‏ 


وبنفس الطريقة يمكنك إضافة موصل جدول الكتب.. لاحظ أن العلاقة بين الجدولين 
سيتم إنشاؤها تلقائيا بمجرد إضافة جدول الكتب.. هكذا سيكون المخطط: 


TID 

Book 
Ip =| AuthorlD 
Author PublisherID 
CountryIP Class 
Phone Fublish_Date 
About Ver 
RowVersion Price 
A AuthorsTableAdapter [4| Copies No 


ا Fill, GetData )( ١ك BooksTableAdapter‏ لبد 
Fill, GetData Û‏ به 























بكم إنشاء هذه الفئة في تفس الملف الذى ترجد فيه فة مجموصة البياناك مهددة 
النوع» وهو في مثالنا هذا الملف 61.11مع51و10541110151300125.106.. لکن فئة 
موصل الجدول لا توضع داخل فئة مجموعة البيانات» بل توضع خارجهاء ويتم 
تعريف نطاق اسم ع 7131265000 خاص بها يكون على الصيغة 
5 كه 11 : حيث × هو اسم فئة عة البيانات.. هكذا مثلا سيكون الشكل 
العام لملف كود فئة البيانات وموصلات الجداول في مشروعنا هذا: 


Partial Public Class DsAuthors Books 
Inherits Global.System.Data.DataSet 
' كود مجموعة البيانات محددة النوع‎ 


دن 


End Class 


Namespace DsAuthorsBooksTable Adapters 
Partial Public Class AuthorsTable Adapter 
Inherits Global.System.ComponentModel.Component 
' كود موصل جدول المؤلفين‎ 
End Class 


Partial Public Class BooksTable Adapter 
Inherits Global.System.ComponentModel.Component 
' كود موصل جدول الكتب‎ 

End Class 


Partial Public Class TableAdapterManager 
Inherits Global.System.ComponentModel.Component 
' كود مدير موصلات الجداول‎ 
End Class 
End Namespace 
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ل الاتصال دروزاءء مده ©- 
تقرأ أو تغير كائن الاتصال الذي يستخدمه موصل الجدول للاتصال بقاعدة 
البيانات.. ويعتمد نوع هذه الخاصية على نوع قاعدة البيانات التي تتعامل 
معهاء وفي مثالنا هذا ستكون من النوع .SqIConnection‏ 
ويس تخدم موصل الجدول إجراءا خاصااں؟ 2217866 اسمه 
Connection‏ لضبط خصائص كائن الاتصال. 


57 زوز الانتقالات :Transaction‏ 
تقرأ أو تغير كائن الانتقالات الذي يستخدمه موصل الجدول للتحكم في 
العمليات التي تتم على قاعدة البيانات.. وفي مثالنا هذا ستكون هذه الخاصية 
من النوع .SqlTransaction‏ 


وخا محو قبل الملء 162113610117111 ©: 
إذا جعلت قيمة هذه الخاصية ں٣1‏ (وهي القيمة الافتراضية)» فسيتم محو 
السجلات من جدول مجموعة البيانات أولاء قبل ملئه بالنتائج الجديدة.. أما إذا 
جعلتها 12156» فسيتم تحديث السجلات الموجودة بالقيم الجديدة» وإضافة 
السجلات الجديدة إلى الجدول. 


ملحوظة: 

موصل الجدول يستخدم موصل البيانات داخليا لملء مجموعة البيانات» لهذا 
ستجد في فئة موصل الجدول خاصية محمية Protected Prope‏ اسمها 
016 لن تراها من خارج الفئة» لكن تستطيع استخدامها في الفئات 
التي ترث فئة موصل الجدولء أو في أي كود إضافي تكتبه في موصل 
الجدول بنفسك.. ويس تخدم موصل الجدول إجراء خاصا 
Private Sub‏ اسمه Adapter‏ !ا لوضع القيم في خصائص موصل 
البيانات. 

كما يحتوي موصل الجدول على خاصية محمية أخرى اسمها 
2201 وهي تعيد مصفوفة تحتوي على كائنات الأوامر 
التي يستخدمها موصل الجدول» وبهذا يستطيع موصل الجدول التعامل مع 
أكثر من استعلام كما سنرى لاحقا. 

ويستخدم موصل الجدول إجراء خاصا 5116 م Pa)‏ اسمه 
12 لوضع كائنات الأوامر في هذه المصفوفة 
وضبط خصائصها. 

كما تمتلك فئة موصل الجدول الوسائل التالية: 
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> ملء 15111: 

تستقبل معاملا من نوع الجدول المراد ملؤه بالبيانات» وتعيد عددا صحيحا 
يخبرك بعدد السجلات التي أضيفت أو تم تحديثها في هذا الجدول.. وفي 
موصل جدول المؤلفين» يكون معامل هذه الوسيلة من نوع جدول المؤلفين 
المعرف في مجموعة البيانات «DsAuthorsBooks.AuthorsData Table‏ 
وبالمثل يكون هذا المعامل في موصل بيانات الكتب» من النوع 
.DsAuthorsBooks.BooksDataTable‏ 

لاحظ أنك تستطيع أن ترسل جدولا من جداول مجموعة البيانات إلى هذه 
الوسيلة» أو ترسل جدول حرا ليس مرتبطا بمجموعة بيانات» المهم أن يكون 
من النوع الصحيح. 


#ذ> قراءة البيانات 06)122148: 
لا تستقبل أية معاملات» لكنها تعيد جدولا جديدا مملوءا بالبيانات.. هذا الجدول 
يكون من النوع ع1750151(03481261ىم في موصل جدول المؤلفين» ومن 
النوع 800125103121816 في موصل بيانات الكتب. 


#> تحديث 09)6م11: 

تحفظ التغييرات فى قاعدة البيانات.. لاحظ أن كل ما تفعله هذه الوسيلة» هو 

استدعاء الوسيلة 1700346 الخاصة بموصل البيانات الداخلي.. ولهذه الوسيلة 

الصيغ التالية: 

-١‏ الصيغة الأولى تستقبل كائن الجدول المراد حفظ تغييراته. 

؟- الصيغة الثانية تستقبل كائن مجموعة البيانات» حيث يقوم موصل الجدول 
بقراءة التغييرات من الجدول الخاص به في مجموعة البيانات» دون غيره 
من الجداول.. مثلا: تستخدم هذه الصيغة الكود التالي في موصل جدول 
المؤلفين: 

Return Me.Adapter.Update(dataSet, "Authors'"") 

"- الصيغة الثالثة تستقبل كائن صف البيانات 1031210597 الذي تريد حفظ 
تغييراته فى قاعدة البيانات. 

-٤‏ الصيغة الرابعة تستقبل مصفوفة تحتوي على صفوف البيانات التي تريد 
حفظ تغييراتها فى قاعدة البيانات. 1 

5- الصيغة الخامسة تستقبل قيم الصف المراد حفظه في قاعدة البيانات.. 
ولهذه الصيغة عدة معاملات» كل منها يستقبل قيمة أحد الأعمدة الموجودة 
في الصف.. مثلاء ستحتوي هذه الوسيلة في موصل بيانات المؤلفين على 
هذه المعاملات بالترتيب: «About ‘Phone <CountryID «Author‏ 
.Original RowVersion <‘Original ID‏ 
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5- الصيغة السادسة تزيد على الصيغة السابقة بمعامل إضافي يستقبل المفتاح 
الأساسي للجدول (الحقل (11 في مثالنا هذا). 

وتعيد هذه الوسيلة عددا صحيحا يخبرك بعدد السجلات التي تم تحديثها في 

قاعدة البيانات» فإذا كان الناتج صفراء فهذا معناه حدوث مشكلة تطابق 

.Concurrency Violation 


:Insert إدراج‎ 

تدرج صفا جديدا في قاعدة البيانات.. ولهذه الوسيلة عددا من المعاملات بعدد 
أعمدة الجدول» لاستقبال قيم الصف المراد إضافته. 

وتعيد هذه الوسيلة عددا صحيحا يخبرك بعدد السجلات التي أضيفت إلى قاعدة 
البيانات» فإذا كان الناتج صفراء فهذا معناه أن قاعدة البيانات رفضت إدراج 
الصف بسبب وجود مشكلة في قيمة إحدى خاناته. 


حذف ع]1(16: 

تخذف سجلا من قاغدة البيانات:. تميق هذه الوسيلة السحل باستقيال مفقاحة 
الأساسي (011©1021_11 وإصداره Original Row Version‏ كمعاملين.. 
لاحظ أننا لا نستخدم إصدار السجل في جدول الكتب» لهذا تمتلك هذه الوسيلة 
في موصل جدول الكتب معاملات بعدد حقول الجدول» للبحث عن السجل 
الأصلي في قاعدة البيانات بدلالة كل قيمه. 

وتعيد هذه الوسيلة عددا صحيحا يخبرك بعدد السجلات التي تم حذفها من 
قاعدة البيانات» فإذا كان الناتج صفذفراء فهذا معناه حدوث مشكلة تطابق 
.Concurrency Violation‏ 
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إضافة استعلامات جديدة إلى موصل الجدول: 

إلى الآن» لا يبدو أن موصل الجدول يقدم شيئا جديدا يميزه عن موصل البيانات 
العادي.. فالحقيقة أن مزية موصل الجدول الرئيسية» هي قدرتك على إضافة أي 
عدد تريده من الاستعلامات إليه» ما دامت تلتزم بأحد الشرطين التاليين: 

-١‏ أن تعيد سجلات لها نفس تركيب الجدول الذي يتعامل معه موصل 
الجدول.. ليس من المنطقي مثلا أن تضيف إلى موصل جدول المؤلفين» 
ابتكعلاما بد عاذت الكتب. 

-١‏ أن تعيد قيمة منفردة 772116 502131.. يمكنك مثلا أن تضيف إلى موصل 
جدول المؤلفين استعلاما يعيد عدد المؤلفين» أو عدد كتب أحد المؤلفين. 

والإضافة استعلام :حديه إلى موصل الخدول» اضخط اسح الموضيل فى ذاقذة المصيهم 
بزر الفأرة الأيمن» ومن القائمة الموضعية اضغط الأمر 116137 © 400.. سيؤدي 
هذا إلى بدء المعالج السحري لتهيئة استعلام موصل الجدول TableAdapter‏ 
..Query Configuration Wizard‏ دعنا نستخدم هذا المعالج لإضافة استعلام 
إلى موصل جدول الكتب» يعيد كتب المؤلف الذي نريده: 

- النافذة الأولى تسألك عن نوع الاستعلام الذي تريده (جملة ,501 أم إجراء 
مخزن).. اختر Use SQL Statement‏ واضغط .Next‏ 

- النافذة التالية تسألك عن نوع الاستعلام الذي تريده: 


LET ETTI ARICA IGS 1 2× 


Choose a Query Type < ا‎ 
Choose the type of query to be generated | 1 1 


Y¥hat type of SQL query would you like to use? 
(® SELECT which returns rows 
Returns one or many rows or colurnns, 
(` SELECT which returns a single value 
Returns a single value (for example, Sum, Count, or any other aggregate function). 
f UPDATE 
Changes existing data in a table. 
f DELETE 
RemoYes rows from a table, 
f INSERT 
Adds a new row to a table, 





< Previous | nexe>_| Fils | Cancel | 
0 


يمكنك الاختيار من بين الأنواع التالية: 
أ. جملة استعلام تعيد صفوفا: 
SELECT statement witch returns 75.‏ 
ب. جملة استعلام تعيد قيمة منفردة: 


5١ 





SELECT statement witch returns a single value. 
لا.‎ P0۸۲٤ ت. تحديث‎ 
.DELETE ث. حذف‎ 
.INSERT ج. إدراج‎ 
اختر أول اختيار» واضغط غيبرع]8.‎ 
في النافذة التالية اكتب جملة الاستعلام التالية:‎ - 
SELECT  85001:5.* 
FROM Books INNER JOIN Authors 
ON Books.AuthorID = Authors.ID 
AND Author = (@Author 
.N٥× واضغط‎ 
النافذة التالية تتيح لك اختيار الوسائل التي ستضاف إلى موصل جدول‎ - 
الكتب لتنفيذ هذا الاستعلام.. ستجد وسيلتين هما:‎ 
أ. 111183 وعليك تعديل اسمها إلى 01ط]111183:11» وهي تستقبل‎ 
اسم المؤلف» وتملأ جدول الكتب في مجموعة البيانات بكتب هذا‎ 
المؤلف.‎ 
«GetDataByAuthor وعليك تعديل اسمها إلى‎ «GetDataBy ب.‎ 
وهي تستقبل اسم المؤلف» وتعيد جدول كتب يحتوي على كتب هذا‎ 


المؤلف. 
- اضغط Ne×x)‏ لعرض نافذة الملخص» ثم اضغط Finish‏ لإنهاء المعالج 
السحري. 
سيؤدي هذا إلى ظهور اسمي : 
الوسيلتين الجديدتين في مخط ط BooksTableAdapter‏ 8 





o 
لوه‎ FINByYAuthor, GetDataByAuthor (@Author) گن الصبو رة المجاورة.. هد | هنا أن‎ 

تعريف هاتين الوسيلتين قد أضيف إلى فئة موصل الجدول» وسيكون لكل منهما 
معامل نصي يستقبل اسم المؤلف.. وعموماء يقوم موصل جدول الكتب بتعريف 
المعاملات المناسبة لنوع الحقل الذي تستعلم عنه في قاعدة البيانات. 

لاحظ أنك لو استخدمت استعلاما يعيد نتائج غير مرغوبة»ء فسيعرض لك موصل 
الجدول رسالة تحذرك من أن نتيجة الاستعلام لا تناسب مخطط الجدول.. ولو 
أردت تصحيح الاستعلام فاضغط بزر الفأرة الأيمن» فوق الصف الذي يعرض 
اسمي الوسيلتين الجديتين في مخطط موصل الجدولء ومن القائمة الموضعية 
اضغط الأمر ١إuعگره)..‏ سيعرض هذا النافذة التي أدخلت فيها الاستعلام» حيث 
يمكنك تصحيحه كما تريد وضغط الزر طینہا۴. 

ولحذف الاستعلام» حدده في مخطط مو صل الجدول» واضغط مع)ع][م5. 


۲ 


دعنا أيضا ننشئ استعلاما في موصل جدول الكتب يعيد لنا عدد كتب مؤلف معين.. 
دعنا نجرب طريقة أخرى هذه المرة.. من صندوق الأدوات اسحب العنصر 
0106137 وأسقطه فوق موصل جدول المؤلفين.. سيؤدي هذا إلى إطلاق المعالج 
SELECT Statement that returns a single value‏ 

وفي نافذة الاستعلام اكتب: 
SELECT COUNT(BOOK) FROM Authors, Books‏ 
WHERE AuthorID = Authors.I[D AND Author = @Author‏ 
واضغط ×عN..‏ ستظهر لك نافذة تتيح لك تسمية الدالة التي تنفذ هذا الاستعلام.. 
سيكون لهذه الدالة الاسم الافتراضي 50213100101617.. غير هذا الاسم إلى 
Get AuthorBooksCount‏ واضغط طوiم۴1..‏ سيظهر اسم الدالة الجديدة في 
مخطط موصل الجدول كما في الصورة» كما ستضاف هذه الوسيلة إلى فئة موصل 
الجدول» حيث ستستقبل نصا يمثل اسم 


المؤلف» وتعيد عددا صحيحا بمثل عدد كتبه. 
لمؤلف» وتعب بحاد GetData Û‏ راازع All‏ 
al GetûauthorBooksCount (@Author)‏ 


ملحوظة١:‏ 
عند إنشاء الاستعلام عن حقل يمكن تركه فارغا (مثل الحقل عمط في جدول 
الكتب)» يقوم موصل البيانات بتعريف معامل الوسيلة 11112837 بحيث يكون قابلا 
للانعدام 71101198516 (مثلا: سيكون معامل الوسيلة ©6مط11112838:5 من نوع 
النص المنعدم 7ع530).. هذا يتيح لك إرسال القيمة عمنطاه× إلى هذه 

الوسيلة لتعيد إليك السجلات التي ما زال فيها هذا الحقل فارغا. 


5 AuthorsTableAdapter A 








YY 

















ملحوظة؟ : 
إذا أردت إضافة وسيلة لتنفيذ إجراء مخزن» فاتبع نفس الخطوات المألوفة 
لإضافة استعلام» لكن هذه المرة اختر نوع الاستعلام: 

Existing Stored Procedure 
ستظهر نافذة تعرض قائمة منسدلة بها أسماء الإجراءات‎ ..Next واضغط‎ 
المخزنة في قاعدة البيانات.. اختر الإجراء 2©1]4114011300[15).. سيعرض‎ 
النصف السفلي من النافذة بيانات هذا الإجراء المخزن: على اليسار ستظهر‎ 
معاملات الإجراءء وعلى اليمين ستظهر الأعمدة الناتجة عن تنفيذه» كما هو‎ 


موضح في الصورة: 
ableAdapter Query Configuration ¥izard 2×‏ 
Choose an existing stored procedure ۵ |‏ 
Choose which stored procedure the DataSource Function is supposed to call, . - |‏ 





Parameters: Results: 


Parameter Names Result Columns 
@Author Book 


< Previous | حمر‎ [ Finish | Cancel | 
2 


اضغط ×م للانتقال إلى النافذة التاليةء وهى تسألك عن القيمة العائدة من 
الوسيلة التي ستنفذ الإجراء المخزن.. هذه القيمة قد تكون: 
- قيمة جدولية 77211 ٣وا‏ اه 1»ء حيث تعيد الوسيلة كائن جدول يحتوي 
على الصفوف الناتجة. 
- قيمة منفردة 17106 ماعم1؟ء حيث تعيد الوسيلة قيمة أول خانة في أول 
عمود في النتيجة. 
- ولا قيمة 77116 2[0» حيث ستكون الوسيلة بدون قيمة عائدةء وهذا 
مناسب للإجراءات المخزنة التي لا تعيد ناتجا. 
اختر ما يناسبك واضغط غ)6زع71.. باقي الخطوات لا جديد فيها. 








٤ 

















إنشاء استعلامات عامة :Global Queries‏ 

يمكنك إنشاء موصل جدول لتنفيذ استعلامات عامة» كحساب دالة تجميع» أو تنفيذ 
استعلامات الحذف والإدراج دون أن يكون مرتبطا بجدول معين في مجموعة 
البيانات.. لفعل هذاء اضغط بزر الفأرة الأيمن في أي منطقة خالية من مصمم 
مجمو عة البيانات» ومن القائمة الفرعية 4010 اضغط الأمر Query‏ .. أو اسحب 
سيبدأ هذه المرة بنافذة اختيار الاتصال بقاعدة البيانات» ثم يستمر بنفس الخطوات 
السابقة» لكنك لن تستطيع إنشاء استعلام يعيد سجلات بهذا المعالج.. يمكنك فقط 
إنشاء استعلامات تعيد قيما منفردة» أو استعلامات التحديث والحذف والإدراج.. 
وبعد أن تنهي المعالج» ستجد موصل جدول جديد قد أضيف إلى مجموعة البيانات» 
وسيكون اسمه 1ع]م02خرء01161165121© وهو اسم لا يمكنك تغييره.. وأية 
استعلامات عامة أخرى ستنشئها ستضاف إلى هذا الموصل,» وقد أضفنا إليه في 
مشروعنا هذا الدالة 015000114 11ش]ع 6 التي تعيد عدد المؤلفين» والدالة 
+06800125000 التي تعيد عدد الكتب. 


عام دلقع اناد دع تعن 0 ا 


a GetBooksCount )(‏ 
تذكر مرة أخرىء» أن موصل جدول الاستعلامات لا يتعامل مع استعلامات أو 
إجراءات مخزنة تعيد سجلات.. هو فقط يتعامل مع استعلامات أو إجراءات مخزنة 
تعيد قيما مفردة» وإذا اخترت إجراءا مخزنا يعيد سجلات» فستعيد هذه الوسيلة قيمة 
أول خانة في أول صف في النتيجة! 





Yo 


معاينة بيانات مجموعة البيانات: 

يمكنك معاينة نتيجة أي دالة في موصل الجدول» بالضغط بزر الفأرة الأيمن في أي 
موضع خال في مصمم مجموعة البيانات: أو فوق تصميم أحد الجداول أو أحد 
موصلات الجداول» وضغط الأمر واه 1و2 من القائمة الموضعية.. 
وستجد نفس الأمر في القائمة الرئيسية هة. 

ستظهر نافذة عرض النتائج» حيث يمكنك إسدال القائمة العلوية» واختيار موصل 
الجدول الذي تريده» والدالة التي تريد تنفيذها منه» ثم وضع المعاملات في الجدول 
الموجود علد يمين النافذة إن كانت الدالة تحتاج معاملات» ثم ضغط الزر 
177 لرؤية النتيجة. 


mar x 
Select an object to preview: Parameters: 


[PsAuthorsBooks.cetauthorsCount 9 -[ | Name | Type | value 


larget DataSet: No parameters are defined on the selected object. 
4 





Results: 


Columns: 1 Rows: 1 Close | 





Select an object to preview: Parameters: 


[PsAuthorsBooks, Books, FIIByAuthor, cetDataB: > | | Name | Type | Yalue 


5 : ١ 
Target DataSet: O Author String | توفيق الحكيم‎ 


۶ 


Preview | 





Results: 

ID | Book AuthorID | PublisherID | ClassID | Publish_Date | Ver Copies_No 
6 (12/30/1998 1 Û8... 300 

5 812002 5 .... 300 

3000| ...15 10 112000 5 يوميات نائب في الأرياف | _ 36 

















Columns: 9 Rows: 3 Close | 
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2 فئة مدير موصلات الجداول TableAdapter Manager‏ 


ظهرت هذه الفئة في دوت نت »35٠٠8‏ ويتم إنتاجها آليا عند إنشاء موصلات 
الجداول التي تربطها علاقات» لتسمح لك بإجراء التحديث المتراكب 
Hierarchical Update‏ وفيه يتم تحديث الجداول المترابطة معاء مع قدرتك 
على تحديد الترتيب الصحيح لإجراء عمليات التحديثء لمراعاة القيود المفروضة 
على الجداول: 

لاحظ أنك تستطيع منع إنتاج هذه الفئة.. لفعل هذا اضغط بزر الفارة الأيمن في أي 
موضع فارغ من مخطط مجموعة البيانات» ومن القائمة الموضعية اضغط الأمر 
و11 : وفي ناف ذة الخصائص غير قيمة الخاصية 
Hierarchical Update‏ إلى .False‏ 


وكنتلك هذه الفئة الخصائص الثالية: 


ونج الاتصال :Connection‏ 
تقرأ أو تغير كائن الاتصال المستخدم في عملية التحديث. 


وخ مدير موصل الجدول... :XTableAdapter‏ 
الحرف > الذي وضعناه في بداية اسم هذه الخاصية هو بديل عن اسم أحد 
الجداول.. هذا معناه أن مدير موصلات الجداول يمتلك خاصية لكل موصل 
جدول تم تعريفه في مجموعة البيانات.. وفي مشروعنا هذا ستحتوي فئة 
المدير على الخاصيتين AuthorsTable Adapter‏ و .BooksTableAdapter‏ 
وتكون لهذه الخصائص القيمة 71011218 إلى أن تضع في كل منها موصل 
الجدول الذي تريد أن يتحكم فيه مدير الموصلات. 


37 ف عدد نسخ موصلات الجداول :TableAdapterInstanceCount‏ 
تعيد عدد نسخ موصلات الجداول التي لها قيمة غير ع منتطاه1. 


¥ 


سخ مجمورعة البيانات احتياطيا قبل التحديث 
:BackUpDataSetBefore Update‏ 
إذا جعلت قيمة هذه الخاصية عںإ]۰ فسيتم حفظ نسخة احتياطية من مجموعة 
البيانات قبل إجراء عملية التحديث.. يحدث هذا بتعريف مجموعة بيانات داخل 
إجراء التحديث» وحفظ سجلات مجموعة البيانات الأصلية فيها.. هذا مفيد إذا 
حدث خطأ أثناء عملية التحديث» ففي هذه الحالة سيتم التراجع ع1[ء1201102 عن 
كل العمليات التى أجريت على قاعدة البيانات» وستستعيد مجموعة البيانات 
الأصيلية حالقينا الشايقة قل اجر عة التصديك» وذانك باس تاا من 
مجموعة البيانات الاحتياطية.. لاحظ أن أخذ نسخة احتياطية من مجموعة 
بيانات ضخمة سيكون عبئا على الذاكرة وسيستهلك وقتا لتنفيذه» لهذا فالقيمة 
الافتراضية لهذه الخاصية هي ع1"215. 


وخ ترتيب التحديث :UpdateOr der‏ 
تحدد ترتيب تنفيذ أوامر التحديث والإدراج والحذف عند إجراء عملية 


0 


التحديث» وهي تأخذ إحدى قيمتي المرقم ونام ۲0ء لإ 0ء لمل التاليتين: 
تنفيذ أوامر الإدراج ثم التحديث ثم الحذف.. هذه 
القيمة الافتواضنية. 

011[ تنفيذ أوامر التحديث ثم الإدراج ثم الحذف. 


InsertUpdateDelete 











وكمتلك هذه الفقة الوسيلة الوحيدة الثالية: 


7# تحديث الكل 4[[1ع1100121]: 

أرسل إلى هذه الوسيلة مجموعة البيانات محددة النوع التي تريد نقل التغييرات 
منها إلى قاعدة البيانات.. في مشروعنا ستكون مجموعة البيانات من النوع 
65+ رويتم إجراء عمليات التحديث بالترتيب الموضح في 
الخاصية 036601061م11؛ وإذا حدث خطأ في أي مرحلة من مراحل 
التحديث» يتم التراجع 12011631 عن تنفيذ جميع عمليات التحديثء أي أن 
قاعدة البيانات لا يحدث بها أي تغييرء وتظل كما كانت قبل استدعاء هذه 
الوسيلة. 


۸ 











إضافة أكواد خاصة بك إلى مجموعة البيانات والجداول وموصلات الجداول: 
يمكنك أن تضيف بعض الوسائل إلى فئة مجموعة البيانات» أو فئة الجدول» أو فئة 
موصل الجدول.. كما يمكنك كتابة إجراءات تستجيب لبعض أحداث فئة الجدول» 
سواء الأحداث المعرفة داخل فئة الجدول» أو تلك الموروثة من الفئة 2103421816 
والتي سنتعرف عليها في الفصل التالي. 
لكن المشكلة أنك لو كتبت أي كود في الملف 1.176ومع1و»7].12 الذي فيه تعريف 
هذه الفئات (حيث × هو اسم مجموعة البيانات)» فسيكون هذا الكود عرضة 
للضياع عند قيامك بأي تعديلات في مصمم مجموعة البيانات» لأن هذه التعديلات 
ستعيد إنتاج ملف الكود من جديد» وستتخلص من أي كود خاص بك! 
لحل هذه المشكلةء تم تعريف الفئات في هذا الملف باعتبارها جزئية 25210121 
ليمكنك إضافة الكود إليها في ملف آخر.. لفعل هذاء اضغط بزر الفأرة الأيمن فوق 
الول أذ ول الج ول سكين اة الو عة فين واو 
۰1ew 000‏ لفتح تعريف جزئي مستقل لفئة الجدول أو فئة موصل الجدول.. 
هذا التعريف سيضاف في ملف جديد اسمه 7.0 (في مثالنا هذا سيكون اسمه 
vb‏ 01518001 . وستجد هذا الملف ضمن الملفات الفرعية لمخطط 
مجموعة البيانات .DsAuthorsBooks.xsd‏ 
وعندما تفتح هذا الملف في محرر الكودء يمكنك اختيار الفئة من القائمة العلوية 
اليسرى» واختيار الحدث الذي تريد إضافته إليها من القائمة العلوية اليمنى كما هو 
مألوف.. كما يمكنك أن تضيف أية دالة تريدها إلى أية فئة» سواء كانت خاصة 
Private‏ أو عامة عiاا۴u»‏ مع قدرتك على استخدام كل العناصر المعرفة على 
مستوى الفئة في كتابة كود هذه الدالة سواء كانت هذه العناصر محمية 
Protected‏ و خاصة Private‏ . 
كما يقدم لك مصمم مجمو عة البيانات الكثير من التسهيلات: 
- فالنقر مرتين في أية منطقة خالية» يفتح فئة مجموعة البيانات. 
- والنقر مرتين على عنوان الجدول يفتح فئة الجدول» ويضيف إليها مستجيبا 
للحدث ع رزاع و ط2212070: حيث > هو اسم الجدول.. وقد استخدمنا 
الحدث AuthorsRowDeleting‏ في المشروع Table Adapter‏ 
لعرض رسالة تأكيد قبل حذف أي صف من الجدول. 
- والنقر مرتين على أي صف في الجدولء يفتح فئة الجدول» ويضيف إليها 
تعريفا للحدث ع2ززع170013ن001» وشرطا يتأكد أن العمود الذي تغير 
هو العمود الذي نقرته بالفأرة.. وقد استخدمنا هذا الحدث في المشروع 
"be Adapter‏ لمنع المستخدم من ترك اسم المؤلف فارغا. 
- والنقر مرتين على عنوان موصل الجدول يفتح كود فئته. 


۲۹ 


استخدام موصل الجدول في الكود: 
لاستخدام موصل الجدول يجب أن تعرف نسخة منه.. مثال: 
Dim TaAuhtors As New _‏ 

DsAuthorsBooksTable Adapters. AuthorsTableAdapter 
MsgBox(TaAuhtors.GetAuthorBooksCount(""ميكall (("توفيق‎ 
ولاستخدام مدير الموصلات في الكودء يجب أن نعرف نسخة منه. وتضع نسخة‎ 

من كل موصل جدول في الخاصية المناظرة له في مدير الموصلاتء كالتالي: 
Dim TaBooks As New _‏ 

DsAuthorsBooksTableAdapters.BooksTable Adapter 
Dim TaM As New _ 

DsAuthorsBooksTable Adapters. Table AdapterManager 
TaM.AuthorsTableAdapter = TaAuhtors 
TaM.BooksTableAdapter = TaBooks 
لكن الأسهل هو أن تتعامل مع هذه الكائنات بشكل مرئي» حيث تقدم لك دوت نت‎ 

هذه التسهيلات 
-١‏ عند سحب مجموعة البيانات من صندوق الأدوات وإسقاطها على 
النموذج» ستظهر نافذة تسألك إن كنت تريد إضافة مجموعة بيانات عادية 
أم محددة النوع» حيث تستطيع اختيار النوع X.DsAuthorsBooks‏ من 
القائمة المنسدلة» حيث > هو اسم المشروع (وهو إعامةل۸Aء‏ اه1 في 
حالتنا هذه). 
؟- يمكنك التعامل مع عناصر مجموعة البيانات محددة النوع من صندوق 

الأدوات مباشرة» فهي يظهر في صندوق الأدوات تحت شريط جديد اسمه 
15 كر حيث × هو اسم المشروع.. وإذا لم تجد هذا 
الشريط فأغلق صندوق الأدوات ثم أعد فتحه ليتم إنعاشه.. وستجد تحت 
شريط المشروع 1ع14م13كرء131 العناصر التالية: 

أ. مجموعة البيانات محددة النوع .DsAuthorsBooks‏ 

ب. موصل جدول المؤلفين .AuthorsTable Adapter‏ 

ج. موصل جدول الكتب :رع]1م03 كرء8001251261. 

د. موصل جدول الاستعلامات .QueriesTable Adapter‏ 

ه. مدير موصلات الجداول .TableAdapterManger‏ 
هذا يتيح لك إضافة أي من هذه العناصر إلى النموذج» حيث ستظهر في 
صينية المكونات.. أضف نسخة من كل عنصر من هذه العناصرء وامنحها 
الأسماء التالية على الترتيب: «Ds‏ 015طأتتشه1»؛ 21080015 
1265 . 


r. 


۳- اضغط بزر الفأرة الأيمن» مدير الموصلات 17834 في صينية المكونات» 
ومن القائمة الموضعية اضغط الأمر ]هم٥۴۲‏ لعرض خصائصه في 
Authors 116 11‏ اختر Authors‏ ]» ومن من القائمة 
المنسدلة للخاصية 1ع1م 800513614023 اختر 121800129.. ويمكنك 
تغيير قيمة باقي الخصائص كما يناسبك. 

5 اضغط بزر الفأرة الأيمن» أي موصل جدول في صينية المكونات» ومن 
القائمة الموضعية اضغط الأمر :1613© ۸4 لإضافة استعلام جديد إلى 


الوسيلة 101111893 فقط ولن يتم تعريف الوسيلة 6611(31213.: كما هو 
موضح في الصورة: 


Search Criteria Builder 21× 


Choose anı existing query or enter a new query below, مر‎ ToolStrip will be added to 
the Form to run the query, To edit an existing query or use stored procedures Use 
the Configure command on the TableAdapter in the DataSet Designer. 











Select data source table: 
|DshuthorsBooks Books 5 


Select a parameterized query to load data: 


(f New query name: [FilByPublisher 


(” Existing query name: jFIMByAuthortauthor) 





Query Text: 





SELECT Books,* 
FROM Books INNER JOIN Publishers 
ON Books.,PublisherID = Publishers, ID 
AND Publisher = @Publisher 


Sample: SELECT ColumnName1, ColurnnNarne2 FROM 
TableNarne WHERE ColumnfJame1 = RL a 
@Parameter Name 

OK | Cancel | 
رو‎ 


ويمكنك أن تغير موصل الجدول الذي تتعامل معه من القائمة المنسدلةء 
ويمكنك أن تغير اسم وسيلة الملء بتحريرها في مربع النص 
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(وسنستخدم هنا الاسم 17111893/20115161)» كما يمكنك أن تكتب 
الاستعلام في مربع النص السفلي.. وإذا أردت تعديل استعلام موجود 
سابقا» فاضغط الاختيار ©1112 Existing Query‏ واختر اسم الاستعلام 
من القائمة المنسدلة لعرضه في مربع النص السفلي.. في حالتنا هذه 
سنستخدم استعلاما جديدا للحصول على الكتب التي نشرها ناشر معين. 
اضغط )0 لإغلاق هذه النافذة.. سيؤدي هذا إضافة الوسيلة 
Publisher‏ إلى موصل بيانات الكتب. 


وإذا أردت إضافة الوسيلة ع ط115طن66112021883/2: فاتبع الخطوات 
التالية: 
- ضغط موصل الجدول بزر الفأرة الأيمن» ومن القائمة الموضعية 
اضغط الأمر ]103256 10 dt Query‏ لعرض مخطط مجموعة 
البيانات. 
- اضغط الاستعلام e۲طینااں۲‏ ,۴1118 في موصل جدول الكتب بزر 
الفأرة الأيمن» ومن القائمة الموضعية اضغط الأمر عتتناع 1ه © 
لعرض نافذة تحرير الاستعلام. 
- اضغط Next‏ لعرض نافذة وسائل الاستعلام» وضع علامة الاختيار 
أمام 181481816 Return a‏ وغير اسم الوسيلة إلى 
GetDataByPublisher‏ واضغط Finish‏ . 


أيضاء سيضاف رف أدوات م3غ70015 إلى النموذج» عليه لافتة تحمل 
الاسم إعطءنااPu‏ (وهو اسم المعامل المراد إدخاله لتنفيذ الاستعلام) 
ومربع نص ليكتب فيه المستخدم اسم الناشرء وزرا يحمل اسم الوسيلة 
21151 وعند الضغط عليه سيتم ملء مجموعة البيانات 
بكتب هذا الناشرء فالكود الذي يفعل هذا تم إنتاجه آليا في حدث ضغط 
الزر.. لكن سيتبقى عليك أن تعرض محتويات مجموعة البيانات للمستخدم» 
وقد فعلنا هذا بعرضها في جدول عرض كما هو موضح في الصورة: 


درس 


Publisher: الاد‎ aise FillByPublisher 


l1yg/2000 |‏ | | | گافت لتا لوطات | 
|_1/17/1970] ]| 5 ما وا إسلاماه| 





وتستطيع تغيير عنوان اللافتة والزر» وعرض رف الأدوات من اليمين إلى 
الس 


والمشروع Table Adapter‏ يريك أمثلة على استخدام موصلات الجداول» مع 
استخدام مدير الموصلات في حدث ضغط الزر "حفظ التغييرات" لإرسال 
التغييرات التي أجراها المستخدم على السجلات إلى قاعدة البيانات. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


YY 


1١5" 


الجداول والعلاقات والقيود 


سنتعرف في هذا الفصل على الكائنات الداخلة في تكوين مجموعة البيانات 
1151 وهي: 
- كائن الجدول 17331216 والكائنات الداخلية المكونة له مثل كائن الصف 
1077 وكائن العمود .DataCoulmn‏ 
- كائن العلاقة .DataRelation‏ 
- كائنات القيود 5)مزج)ومه") المختلفة. 
إضنافة إلى المجموهات التي تستخدمها هذه الفكاك: 


4 فة أساس مجموعة البيانات الداخلية 
InternalDataCollectionBase Class‏ 


هذه الففة تمثل واجهة المجموعة 100116»0» ولا تزيد على خصائصها 
ووسائلها بشيء جديد. 

وهذه الفئة هي الفئة الأم لكل من المجموعات التالية: 

DataTableCollection Class . 

DataColumnCollection Class . 

DataRowCollection Class . 

DataRelationCollection Class . 

ConstraintCollection Class . 


O n 4 44 صا‎ 


Y4 


4 فئة مجموعة الجداول DataTableColIlection Class‏ 


هذه المجموعة ترث الفئة ع1001325ع101610211(03132000116» وهي تحتوي على 
عناصر من النوع ع1(343181.. ويمكن الحصول على هذه المجموعة باستخدام 
الخاصيّة blesۆDataSet.Ta.‏ 
والكود التالي يعرض كل أسماء الجداول الموجودة في مجموعة البيانات 1(5: 
For Each TbI As DataTable In Ds.Tables‏ 
MsgBox(tbI.TableName)‏ 
Next‏ 
ولا تضيف هذه المجموعة جديدا إلى خصائص ووسائل واجهة المجموعة 
2 ولكنها تضيف بعض الصيغ إلى بعض هذه العناصرء مثل: 


7 ف العنصر ص ع)!: 
هذه هي الخاصية الافتراضية» وهي تعيد كائن البيانات 102621216 الموجود 
في موضع معين في القائمة.. ولهذه الخاصية ثلاث صيغ: 
-١‏ الصيغة الأولى تستقبل رقم الجدول في المجموعة. 
د والصيغة الكانية فل نصا يمكل انيم الجدل. 
د والصيغة الثالنة تر تة على الصديغة السا تافل كاك مسقل فضا 
يمثل اسم النطاق عع2م5 عمجآ< الذي يوجد تحته الجدول في 
مجموعة البيانات. 
وتعيد هذه الوسيلة عماطاه" إذا لم تجد الجدول المطلوب في المجموعة. 


> إضافة 400: 
تضيف جدولا إلى مجموعة البيانات» ولها أربع صيغ: 

5 الصيغة الأولى بدون معاملات؛ وهي تنشئ جدولا باسم افتراضي 
(1e1ط12‏ أو 126162" وهكذا...) وتضيفه إلى مجموعة البيانات. 

-١‏ الصيغة الثانية تستقبل معاملا نصيّاء هو اسم الجدول الذي سيتمٌ إنشاؤه 
وإضافته إلى المجموعة.. ولو أرسلت إلى هذا المعامل نصا فارغا "", 
فسيسمى الجدول بالاسم الافتراضي 736161 أو 735162 وهكذا... 
لاحظ أن إضافة جدول بنفس اسم جدول موجود سابقا سيؤدي إلى 

"- الصيغة الثالثة تزيد على الصيغة السابقة بمعامل ثان» يوضح نطاق 
الاسم الذي سيضاف إليه الجدول داخل مجموعة البيانات.. هذا يتيح لك 
إضافة اكثر من جدول بنفس الاسم إلى مجموعة الجداول» لكن كلا 


ro 


ف 
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منها ينتمي إلى نطاق مختلف.. هذا مفيد عندما تملا مجموعة البيانات 
بجداول متشابهة الأسماء من أكثر من قاعدة بيانات.. مثلا: 
Ds.Tables.Add('MyTable'", "Db1")‏ 
Ds.Tables.Add("MyTable", "Db2")‏ 
-٤‏ والصيغة الرابعة تستقبل كائن جدول »2103181281 لتتم إضافته إلى 
المجموعة. 
لاحظ أن الصيغ الثلاث الأولى تعيد كائنا من النوع 10942181 يمثل 
الجدول الذي تم إنشاؤه» بينما الصيغة الرابعة هي إجراء لا يعيد أية قيمةء 
وذلك لأنك أرسلت إليها كائن الجدول بالفعل» ولا تحتاج إلى مرجع آخر له. 


يمكن حذفه :Can Remove‏ 
تعيد ع1[ إذا كان من الممكن حذف كائن الجدول 123181816 المرسل 
كمعامل من مجموعة الجداول.. وتعيد هذه الوسيلة 12196 إذا لم يكن الجدول 
موجودا في المجموعة» أو كان داخلا في علاقة.. والكود التالي سيعيد ع18[15 

لأن حذف جدول المؤلفين سيدمر تكامل العلاقة مع جدول الكتب: 
MsgBox(Ds.Tables.CanRemove(Ds.Tables('Authors'"")))‏ 


حذف :Ren0ve‏ 
تحذف الجدول المرسل إليها كمعامل» ولها نفس صيغ الوسيلة 400 ما عدا 
الصيغة الأولى التي بدون معاملات.. لاحظ أنك لا تستطيع حذف جدول من 
مجموعة البيانات إذا كان داخلا في علاقة: فهذا سيؤدي إلى حدوث خطأ في 
البرنامج. . والمقصود بالعلاقة هناء العلاقة المعرفة في مجموعة البيانات» فلو 
وضعت جدولي المؤلفين والكتب في مجموعة البيانات بدون إنشاء علاقة 
بينهماء فسيمكنك حذف أيهما بدون مشاكل رغم أن هناك علاقة بينهما فعلا في 
قاعدة البيانات.. أما لو أنشأت العلاقة بينهما فى مجموعة البيانات» فعليك 
حذفها أولا قبل محاولة حذف أي من الجدولين.. والأفضل استخدام الوسيلة 

76 أولا قبل محاولة حذف الجدول.. مثال: 
Dim T = Ds.Tables('Authors'"")‏ 
If Ds.Tables.CanRemove(T) Then‏ 
Ds.Tables.Remove(T)‏ 
End If‏ 


تحتوي على 1۶و٤ :€C٥‏ 
تعيد ع11” إذا كان الجدول المرسل كمعامل موجودا في مجموعة 3 البيانات.. 
ولهذه الوسيلة صيغتان» تماثلان الصيغتين الثانية والثالثة للوسيلة 5010. 


مون 


#ا> رقم العنصر 170601: 
تيدر كم الجدول ار مل الها سابل إذا كن رة في ام هك 
وتعيد ١-‏ إن لم يكن موجوداء ولها نفس صيغ الوسيلة 400 ما عدا الصيغة 
الأولى التي بدون معاملات. 


كما تمتلك مجموعة الجداول حدثين جديدين» هما: 


المجمو عة تتغير :CollectionChanging‏ 
ينطلق عندما توشك جداول المجموعة على التغير» نتيجة إضافة أو حذف 
ج دول والمعامييل الثياتي ۾ لهذا الح دت مسن التبوع 
sئectionChangeEventArgاC01»‏ وهو يمتلك الخاصيتين التاليتين: 


E 


E 








Action 


Element 





تعيد إحدى قيم المرقم CollectionChangeAction‏ 

التي توضح نوع الفعل الذي سبب تغير المجموعة.. 

وهذه القيم هي: 

- 4010: إضافة عنصر إلى المجموعة. 

- 196110376: حذف عنصر من المجموعة. 

:Refresh -‏ تغير عناصر المجموعة كلهاء بسبب 
بعض الوسائل مثل هم1٥‏ التي تمحو كل العناصر. 

تعيد كائنا ٤زط0‏ يحتوي على العنصر الذي تعرض 

للتغيير.. لاحظ أن قيمة هذا العنصر ستكون عدiطtغNo‏ 

إذا كانت للخاصية ٥٥ا٥۸‏ القيمة Refresh‏ . 


۶ المجموعة تغيرت :CollectionChanged‏ 
يتطلق بعد خدرت التغير فعليا في عناص المجموعة,, والمعائل التي م لهذا 
الحدث من النوع وع 1 شامع ؟1ءع10000328اء00116) الذي تعرفنا عليه في 
الحدف السالق: 


2 فئة جدول البيانات DataTable Class‏ 


تعمل هذه الفئة كوعاء لأحد الجداول بما فيه من أعمدة وصفوف» وهي تمثل 
الواجهة istS our ce‏ 1ء كما أنها ترث الفئة «MarshalByValueComponent‏ 
مما يتيح لك إضافتها إلى صينية مكونات النموذج» وإن كان عليك أن تضيفها أولا 
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إلى صندوق الأدوات.. لكن لا داعي لهذاء فأنت تستطيع التعامل مع الجدول بطريقة 
مرئية في وقت التصميم» بعرض خصائص مجموعة البيانات غير محددة النوع 
51 110-7064 في نافذة الخصائصء واستخدام الخاصية و1816 لإضافة 
الجداول وتغيير خصائصها بطريقة مرئية.. أما إذا كنت تتعامل مع مجموعة بيانات 
دةاأإن وع 
Data€t‏ ed4ءمypا»‏ فيمكنك إضافة الجداول مباشرة إلى مخطط ,2311 بالطرق 
التي تعرفنا عليها في الفصل السابق. 
ولحدث إنشاء هذه الفئة أربع صيغ: 
-١‏ الصيغة الأولى بدون معاملات. 
د والصيعة الثانية تقل معانلا تضتقا نهو اس الجدر ل: 
#ددوالضيغة الكالثة تزيد على السيقة البافة بال كان دوش اة الاب 
الذي سيضاف إليه الجدول داخل مجموعة البيانات. 
-٤‏ والصيغة الرابعة تستقبل معاملين من النوعين SerializationInfo‏ 
و 0ك لنمطو 5 لاستخدامها في سلسلة الجدول 
0--- هذا الموضوع خارج نطاق هذا الكتاب. 





والمثال التالي يعرف كائن جدول ويضع فيه أول جدول في مجموعة جداول 
مجموعة البيانات: 
Dim T As DataTable = Ds.Tables(0)‏ 
والمثال التالي يعرف كائن جدول جديد ويضيفه إلى مجموعة البيانات: 
Dim T As New DataTable("MyTable")‏ 
Ds.Tables.Add(T)‏ 


وخ اسم الجدول :TableName‏ 
تقرأ أو تغير اسم الجدول في مجموعة البيانات. 

3 نطاق الاسم :Namespace‏ 
تحدد اسم النطاق الذي سيندرج تحته الجدول.. هذا يسمح بوجود أكثر من 
حدرل بقن الأسم في مجنو عة البياتات» اذا كان كل هتها في نطاق مكتلف, 


ونج البادئة :Pref¡×‏ 
تقد البادكة التى قر الحدوال كاختسياق لاس طاق 


57 فين مجموعة البيانات 1226]2564: 


TA 


تعيد كائن مجموعة البيانات (a56‏ التي ينتمي إليها هذا الجدول.. وتعيد 
Nothing‏ إذا لم يكن الجدول مضافا إلى مجموعة بيانات حاليا. 


3 تنسيق التعامل عن بعد :RemotingF0ormat‏ 
تحدد التنسيق الذي سيتم به إرسال بيانات الجدول من جهاز إلى اخرء عندما 
التعامل مع برنامج يستخدم التحكم عن بعد «Remoting‏ وهي تأخذ إحدى 
قيمتي المرقم 026ه ”5112112211021 اللتين تعرفنا عليهما سابقا. 


حساس لحالة الأحرف 106) زوم 2565©: 
لوجعلت هذه الخاصية عنمل فستتم مراعاة حالة الحروف 
(صغيرة 520211 أو كبيرة 1121م03)) عند مقارنة النصوص في هذا الجدول. 


المحل 1,022[6: 
تقرا أو تغير كائن معلومات الثقافة 011601111110)» الذي يمثل اللغة التي تريد 
استخدامها لمقارنة وترتيب النصوص. 


وخ أقل سعة :MinimumCapacity‏ 
تحدد أقل عدد من السجلات يمكن أن يحتويه الجدول.. والقيمة الافتراضية 
لهذه الخاصية هى ٠٠‏ سجلا.. وتفيدك هذه الخاصية فى حجز الذاكرة اللازمة 
عند التعامل مع جداول ضخمة الحجم» لتحسين كفاءة البرنامج» فأنت تحدد 
سعة مبدئية كبيرة لحجز الذاكرة المناسبة» بدلا من أن يتم حجز ذاكرة 
صغيرة» ثم يضطر البرنامج إلى زيادتها أكثر من مرة أثناء تشغيله. 


۲۹ 


57 زوز الأعمدة :Columns‏ 
تعيد مجمو عة الأعمدة 1(3120001111100011601100 الموجودة في هذا 


الجدول.. وسنتعرف على هذه المجموعة بالتفصيل لاحقا. 


57 ف الصفوف :۸R0 Ws‏ 
تعيد مجمو عة الصفوف 110ع1(21312079000116 الموجودة في هذا الجدول.. 
وسنتعرف على هذه المجموعة بالتفصيل لاحقا. 


557 ف العلاقات الرئيسية :ParentRelations‏ 
تعيد نسخة من مجموعة العلاقات م10]ء1(212161302000116 تحتوي على 
العلذكات الخارحة من .هذا الحدول (العلاقات الذي يدخل فيها كجدول ركسي 
..{Master Table‏ وسنتعرف على الفئنة DataRelationCollection‏ 
بالتفصيل لاحقا. 


57 ف العلاقات الفرعية :Child Relations‏ 
تعيد نسخة من مجموعة العلاقات ٣0ء11 ›DataR elation‏ تحتوي 
على الغلاقات القادمة إلى هذا الجدول (العلافات اتی يدخل فيها كجدول 
فرعي أو جدول التفاصيل 121 12618115). 


ال المفتاح الأساسي :PrimaryKey‏ 

تستقبل هذه الخاصية مصفوفة أعمدة 41123 دصuاه٣ه†ه0؛‏ تحتوي على 
الأعمدة التي تريد استخدامها كمفتاح أساسي للجدول.. ويمكنك استخدام 
مصفوفة بها خانة واحدة إذا كان المفتاح الأساسي يتكون من عمود واحد» أو 
استخدام مصفوفة بها أكثر من خانة إذا كنت تستخدم عمودين أو أكثر معا 
كمفتاح رئيسي للجدول.. مثلا: لو كان لديك جدول به عمود للاسم الأول 
للشخص»› وعمود آخر لاسمه الأو سط وعمود ثالث لاسمه الأخير» فكل عمود 
من هذه الأعمدة لا يصلح بمفرده كمفتاح أساسي بسبب تكرر الأسماء به بينما 
قد تصلح الأعمدة الثلاثة معا كمفتاح أساسي» لان الاسم الثلاثي نادرا ما 
يتكرر. . كل ما عليك في هذه الحالة هو وضع كائنات هذه الأعمدة في 
مصفوفة ووضعها في هذه الخاصيةء لتصير هذه الأعمدة المفتاح الأساسي. 
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5 زوز القيود :Constraints‏ 
تعيد مجموعة القيود 110ع00125112100116) الموجودة في هذا الجدول.. 


7 ف العرض الافتراضي 12612111)5171686: 
تعيد كائن العرض اء زا0 12343171677 الذي يحمل مبدئيا كل بيانات 
الجدول الحالي» لكنك تستطيع ضبطه لعرض جزء فقط من سجلات الجدول 
تبعا لشرط معين.. وسنتعرف على فئة عرض البيانات Class‏ 102121165 
بالتفصيل في الفصل التالي. 


وخ تعبير العرض 55102ع:12150127:1:01: 
تقرأ أو تغير النصّ الذي سيتمٌ عرضه للمستخدم كعنوان للجدول في أدوات 
عرض البيانات كالأداة 5ع103]80110171. 


:HasErrors به أخطاء‎ FF 
تعيد 116 إذا كانت هناك أيّة أخطاء في أي صف في هذا الجدول.‎ 


57 ف الخصائص الإضافية :Extended Properties‏ 

تعيد مجموعة الخصائص 6117001160110م20 التي تحتوي على 
الخصائص الإضافيّة للجدول.. والمثال التالي يضيف خاصية اسمها 
010 إلى جدول الكتب» ويضع فيها القيمة "كلمة المرور"» ثم يغيرها 

الى "احم 
Dim T As DataTable = Ds.Tables('"Books'"")‏ 
Dim EP As PropertyCollection = T. ExtendedProperties‏ 
("كلمة المرور"' EP.Add ("Password",‏ 
"أحمد” EP.Item("Password") = "١ ١‏ 
MsgBox(EP("'"Password"))‏ 


كما يمتلك كائن الجدول الوسائل التالية: 


۲٤١ 


نسخ :Clone‏ 
تعيد كائن جدول 123431816 جديداء وتنسخ إليه مخطط الجدول الحالي 
8 بكل ما فيه من أعمدة وقيود.. ولكنَ الجدول الناتج يكون فارغا من 

السجلات. 


نسخ [م00): 
تعيد كائن جدول 123818516 جديداء وتنسخ إليه الجدول الحالي بمخططه 
وسجلاته» ليكون مماثلا للجدول الأصلي تماما. 


محو 2و1 ): 
تمحو كل السجلات الموجودة في الجدول. 


تصفير اع وع12: 
تفرغ الجدول تماما من كل أعمدته وسجلاته وقيوده. 


:New R0 w صف جديد‎ > 


تنشئ سجلا جديدا له نفس مخطط الجدول (نفس الأعمدة بنفس أنواع بياناتها 

بنفس ترتيبها)ء وتعيد إليك كائن الصف :27348120 الذي يشير إلى هذا 

السجل» لكن دون إضافته إلى مجموعة صفوف الجدول 012008 لهذا عليك 
أن تضيفه إليها بنفسك.. مثال: 

Dim T As DataTable = Ds.Tables("' Authors'") 

Dim R = T.NewRow 

"أحمد شوقي" = R("Author")‏ 

"أمير الشعراء" = R("About")‏ 

R("CountryID") = 1 

T.Rows.Add(R) 


استعارة صف :1mp0/)۸ 0w‏ 
أرسل إلى هذه الوسيلة كائن صف 010313120187 لتنسخه وتضيفه إلى الجدول 
بكلّ بياناته وخصائصه. بما في ذلك النسخة الأصلية Original Version‏ 

والنسخة الحالية 17615102 Curren‏ لقيم خاناته. 
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ھا تحميل صف :1,0201(262120: 
استخدم هذه الوسيلة لتحديث أحد سجلات الجدول» أو إضافة سجل جديد إليه.. 
وتستقبل هذه الوسيلة معاملين: 
- مصفوفة كائنات 431237 06[601»: تحتوي على قيم خانات السجل 
بنفس ترتيبها في الجدول.. لاحظ أن هذه الوسيلة ستبحث في الجدول» 
لترى إن كان المفتاح الأساسي لأي حقل له نفس القيمة الموجودة في هي 
الخانة المناظرة في المصفوفة.. فإذا كان المفتاح الأساسي موجودا في 
الجدول» يتم نسخ باقي القيم من المصفوفة إلى باقي حقول السجلٌ 
لتحديثها.. وإذا لم يكن المفتاح الأساسي موجوداء يتم إنشاء سجلٌ جديد 
وتوضع بحقوله قيم المصفوفة. 
لاحظ أن ترك إحدى خانات المصفوفة فارغة»ء سيؤدي إلى وضع 
القيمة الافتراضية في العمود المناظر لها إن كانت له قيمة افتراضية: 
أو سيتم توليد الترقيم التلقائي إذا كانت للخاصية 110121610616 
لهذا العمود القيمة 156.. فإذا لم يكن هذا أو ذاكء وكانت الخانة لا 
تقبل أن تظل فارغة» فسيحدث خطأ في البرنامج. . ويحدث خطأ أيضا 
إذا كان عدد خانات المصفوفة أكبر من عدد أعمدة الجدول. 
- معامل منطقي ۰80٥1٥2۸‏ لو جعلت قيمته ع1]' فسيتم استدعاء 

الوسيلة وعع01012عع8,0, بعد إضافة السجل إلى الجدول وبهذا 
يعتبر هذا السجل سجلا أصليا لم يحدث له أي تغيير.. أما إذا جعلثك 
قيمة هذا المعامل ع1'15» فسيعتبر السجل الجديد سجلا مضافا 
0 ويعتبر السجل الذي تم تحديثه سجلا معدلا 2/10011560. 

وتعيد هذه الوسيلة كائن صف 10381507 يحمل مرجعا إلى الصف الذي تم 

قنك أو إضافقة. 


ملحوظة: 

تقوم فئة المجموعة المحددة النوع 01355 10342564 0عم/159»: بتعريف عدة 
وسائل متحدةة لذو ع في كل جدول التعامل مع صقو فة .على سيل المثال» لو 
كان في المجموعة محددة ا المؤلفين اسمها 
11 وتم تعريف فئة اسمها 4111101515018 تمثل نوع 
صفوف هذا الجدول» فإن هذا الجدول سيحتوي على الوسائل التالية: 
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7# صف مؤلفين جديد :NewAuthorsRow‏ 

تعيد كائنا من النوع 1115015185038 يمثل صفا جديدا من صفوف 

جدول المؤلفين» بحيث يمكنك إضافته إلى جدول المؤلفين.. مثال: 
Dim R = Ds.Authors.NewAuthors Row‏ 
"أحمد شوقي" = R.Author‏ 
"أمير الشعراء" = R.About‏ 
R.CountryID = 21‏ 
Ds.Authors.AddAuthorsRow(R)‏ 


7# إضافة صف المؤلفين 041161201519018 4: 

تستقبل هذه الوسيلة معاملا من النوع 1140151401 يمثل صفا من 

صفوف جدول المؤلفين» لإضافته إلى جدول المؤلفين» كما رأينا في 

المثال السايق. 1 

وتوجد صيغة أخرى لهذه الوسيلة تستقبل قيم صف المؤلفين لإضافته 

إلى الجدول في خطوة واحدة.. هكذا مثلا يمكن اختزال المثال السابق: 
,"" ,21 ,"أحمد شیوقي'( Ds.Authors.AddAuthors Row‏ 

Nothin8(‏ ,"أمير الشعراء" 

لاحظ أننا أرسلنا نصا فارغا إلى خانة رقم الهاتف» كما وضعنا القيمة 

Nothing‏ في خانة طابع الوقت لأن قاعدة البيانات تولدها تلقائيا.. أما 

المفتاح الرئيسي لهذا الصف (وهو الحقل 10) فلم تطالبنا به هذه 

الوسيلة أصلا لأنها تعرف أنه يولد تلقائيا. 


#> حذف صف المؤلفين :RemoveAuthors Row‏ 
تستقبل هذه الوسيلة معاملا من النوع 110151901 يمثل صفا من 
صفوف جدول المؤلفين» لحذفه من جدول المؤلفين. 





7# تحديد )ع16ع5: 


تعيد مصفوفة صفوف 411237 1(31819017» تحتوي على بعض أو كل 
صفوف الجدول.. ولهذه الوسيلة الصيغ التالية: 
-١‏ الصيغة الأولى بدون معاملات» وهي تعيد مصفوفة تحتوي على كل 
سجلات الجدول. 
؟- الصيغة الثانية تستقبل معاملا نصّياء يمثل الشرط الذي على أساسه 
سيتم اختيار السجلات من الجدول» ويمكنك صياغة هذا الشرط بنفس 
قواعد صياغة الفقرة 78/111:1:11 في استعلامات ,50[1.. والجملة 
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التالية تعيد كل الكتب التي تبدأ بحروف تسبق حرف الثاء في الترتيب 
الأبجد- ي : 
)" 'ث' < Dim 1+) ( As DataRow = T.Select ("Book‏ 
ويمكنك أن تستخدم في تكوين الشرط, الدوال والكلمات المستخدمة في 
تكوين شرط الخاصية 165510م103131201.112 التي سنتعرف عليها 
لاحقا. 
"- الصيغة الثالثة تزيد على الصيغة السابقة بمعامل نصي يحدد ترتيب 
الصفوف.. ويتكون هذا المعامل من شقين: 
أ- اسم العمود الذي يتم الترتيب على أساسه (مثل ع[800)»؛ 
أو أي تعبير يجمع بين أكثر من عمودين كناتج ضربهما 
(مثل .(Copies_No * Price‏ 
ب- نوع الترتيب» وهو إحدى الكلمتين التاليتين: 
- 450: للترتيب التصاعدي وهو الترتيب الافتراضي لهذا 
يمكن ألا تكتب هذه الكلمة. 
- 80 (: للترتيب التنازلي. 
والمثال التالى يعرض أسماء الكتب التى تبدأ بحروف تسبق حرف الثاء 
في الترتيب الأبجدي» مرتبة تنازليًا على حسب اسم الكتاب: 
"Book DESC")‏ ," 'ث' > Dim R = T.Select ("Book‏ 
فب الضيكة الرابعة تزين على الضوخة الببائقة مل د من فرح السرف 
5 م مما يتيح لك تحديد حالة السجلات التي 
تريد تطبيق الشرط عليها.. هذا يمكنك من البحث في السجلات 
المضافة أو المعدلة أو المحذوفة... إلخ.. وسنتعرّف على المرقم 
711 بالتفصيل لاحقا. 


0 حساب :Compute‏ 
نبحث في الجدول عدن السجلات التي تحقق الشتوط المرسل إلى المعامل 
الثاني» وتجري على هذه السجلات دالة التجميع Aggregate Function‏ 
المرسلة إلى المعامل الأول. . وتعيد هذه الوسيلة كائنا Object‏ يحمل ناتج 
عملية التجميع.. دعنا نأخذ مثالا: افترض أنك تريد حساب عدد الكتب التي 
تبدأ بحروف تسبق حرف النون في جدول الكتب. . يمكنك فعل هذا باستخدام 

الوسيلة ع106مدم0") كالتالي: 

)" 'ن' > C = ThblIBooks.Compute('"'Count(Book)", "Book‏ 
لاحظ أنك تستطيع إرسال نص فارع إلى المعامل الثاني» وفي هذه الحالة سيتم 
تطبيق دالة الح على جميع سجلات الجدول.. والجملة الثالية ترد إليك 
مجموع نسخ الكتب في الجدول: 
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C = ThblIBooks.Compute("Sum(Copies_No)", "")‏ 
ويو جد عيب خطير في هذه الوسيلة» فهي لا تستطيع حساب دالة التجميع على 
أكثر من عمود مباشرة.. فإذا أردت مثلا أن تحسب مجموع أثمان كل نسخ 
الكتب الموجودة في الجدولء فإن الجملة التالية غير مقبولة: 
C = ThblBooks.Compute("'"Sum(Copies_No * Price)", "")‏ 
ولحل هذه المشكلة» عليك إنشاء عمود جديد في الجدول» واستخدام خاصيّة 
"الصيغة" 1655101م1 الخاصة به لتكون قيم خاناته هي حاصل ضرب 
العمودين المطلوبين» ثم تجري على هذا العمود الحسابات التي تريدها.. 
وسنتعرف الأعمدة المحسوبة بالتفصيل عند التعرف على خصائص كائن 
العمود .DataCoulmn‏ 
وقد استخدمنا هذه الوسيلة في حدث ضغط زر تحميل البيانات في المشروع 
51 لحساب مجموع درجات كل طالب وعرضه في عمود 
"المجموع" في جدول العرض.. السبب في هذا أن مجموع درجات كل طالب 
لا يتم حفظه في الملف» لان عمود "المجموع" مضاف إلى جدول العرض 
فقط وليس موجودا في مجموعة البيانات» لهذا علينا أن نحسب قيمته بأنفسنا.. 
هذا هو الكود الذي يفعل هذا: 
alue = DsStudents.Grades.Compute(‏ /ا.لاء 5111110 
"SUM(Grade)", "StudentID = " & Trim(StdId))‏ 
حيث 5010 هو متغير يحمل رقم الطالب المراد حساب مجموع درجاته. 


7# معرفة التغييرات وعع5هط )6 ©: 
تعيد كائن جدول 103431216 جديداء يحتوي فقط على الصفوف التي تم 
تعديلها أو إضافتها أو حذفها من الجدول الحالي» منذ أن تمّ تحميله أو منذ آخر 
استدعاء للوسيلة .AcceptChanges‏ 
وهناك صيغة ثانية لهذه الوسيلةء تستقبل معاملا من نوع المرقم 
RowState‏ الذي تعرفنا عليه من قبل» لتتمكن من اختيار السجلات 
التي وقع عليها نوع معين من التغيير دون غيره. 


ان 


2# معرفة الأخطاء وعرمم[)©: 
تعيد مصفوفة صفوف 411337 21034318017 تحتوي على الصفوف التي 
حدثت بها أخطاء عند محاولة حفظ الجدول فى قاعدة البيانات» ليمكنك 


ب قبول التغييرات :AccepC‌hanges‏ 
تقوم باستدعاء الوسيلة وعع8 8006100122 الخاصة بكل صف في الجدول. 


7# رفض التغييرات :RejectChanges‏ 
تقوم باستدعاء الوسيلة وععمة ط٤‏ ]1ءء ز٠8‏ الخاصة بكل صف في الجدول. 


ا بدء تحميل البيانات 210201(212اع»136: 
يؤدي استدعاء هذه الوسيلة إلى: 
- إيقاف إرسال التنبيهات 72105211015 إلى فئات 4100.111 التي 
تتعامل مع الجدول.. هذا معناه إيقاف انطلاق الأحداث ہ۷غ 
الخاضة بهذه الفتات: 
- إيقاف تحديث الفهارس 1206:©5. 
- إيقاف التحقق من قواعد الصحّة 065لة:00251. 
وعليك استدعاء هذه الوسيلة قبل البدء فى إضافة عدد كبير من السجلات إلى 
الجدول» لأن تكرار تنفيذ العمليات المذكورة سابقا بعد إضافة كل سجل إلى 
الجدول يستهلك وقتا ملموسا ويجعل البرنامج بطيئاء لهذا من الأذكى إيقافها 
مؤقتاء ثم إعادة تشغيلها بعد الانتهاء من ملء الجدول بالسجلات. 


89> انتهاء تحميل البيانات 192010201(212: 
هذه الوسيلة رديفة للوسيلة 1010201(2142ع86»: وعليك استدعاؤها بعد انتهاء 
كحميل السجلات فى الجدول: لإعادة تشغفيل العمليات الخاصية نالات 
والأحداث والفواردس والقيرة» وييذا تسن هنيد ها هر ر احدة فط بعة اة 
التحميل. 


#أ> دمج :Merge‏ 
تيك ادات الجدول الفرييل العا كمل الى الحذول ا لحا و كنت 
السجلات المضافة موجودة سابقاء يتم تحديث السجلات الموجودة بقيم 
السجلات القادمة. 


FEV 
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ب 


ولهذه الوسيلة نفس صيغ الوسيلة عع1ع1233561.21: مع اختلاف واحد» هو 
أن المعامل الأول في هذه الصيغ هو كائن جدول بيانات 103431816 وليس 
.DataSet‏ 


إنشاء قارئ بيانات :CreateData Reader‏ 

تعيد قارئ بيانات الجدول 61و10343135161:620: الذي يمكنك من خلاله 
العرور عبن كل تسات الحدول الحالى. ررق على ا 
leReaderاab r‏ لاحقا في هذا الفصل. 


كتابة كود المخطط :WriteXm1Schema‏ 

تكتب كود 11> الذي يعبر عن مخطط الجدول الحالي»ء في الملف المرسل 
كمعامل» سواء كان هذا المعامل في صورة نص يمثل اسم الملف» أو كائن 
يتعامل مع الملف من الأنواع Stream‏ أو TextWriter‏ أو .XmlIWriter‏ 
وتوجد صيغة ثانية لهذه الوسيلة» تزيد عليها بمعامل منطقيء إذا جعلت قيمته 
6 فسيتم حفظ مخطط الجداول الفرعية التابعة لهذا الجدول أيضا مع 
طط الجدول الخال 


كتابة الكود :WriteXm]‏ 

تكنب کر دا الذي بمثل سحلات الجدر ل في الننف الترسل عامل 
سواء كان هذا المعامل في صورة نص يمثل اسم الملف. > أو كائن يتعامل مع 
الملف من الأنواع Stream‏ أو TextWriter‏ أو .XmIWriter‏ 

ولبعض صيغ هذه الوسيلة معامل منطقي» إذا جعلت قيمته 106" فسيتم حفظ 
سات الحداول ار ع القابعة لهذا الخ ابض 

ولبعض صيغ هذه الوسيلة معامل من نوع المرقم ع17/100ع11171جمكة الذي 
تر تا عليه ساق لقبتطيع من خلاله اختيار:ظريفة حفط البيائات: 


قراءة كود المخطط :ReadXımI1ISchema‏ 

تقرأ مخطط جدول أو أكثر من الملف المرسل كمعامل» سواء كان هذا المعامل 
في صورة نص يمثل اسم الملف. أو كائن يتعامل مع الملف من الأنواع 
Stream‏ أو 1177161 أو :11111161روة.. وتضيف هذه الوسيلة هذه 
المخططات إلى الجدول الحالي والجداول الفرعية التابعة له. 


FEA 


©ا> قراءة الكود [دم10903: 
تقرأ سجلات جدول أو أكثرء من الملف المرسل كمعاملء» سواء كان هذا 
المعامل في صورة نص يمثل اسم الملف. أو كائن يتعامل مع الملف من 
الأنواع Stream‏ أو rext Writer‏ أو ..>m]1Writer‏ وتضيف هذه الوسيلة 
هذه السجلات إلى الجدول الحالي والجداول التابعة له. 


كما يمتلك كائن الجدول الأحداث التالية: 


2 العمود تغير :ColumnChanged‏ 
کن معد أن کر رحد القيم في لعن اعفد ال رل راان رای 
لهذا الحدث من النوع gs‏ umnChangeEven†AاDataC0»‏ وهو يمتلك 
الخصائص التالية: 


Column E‏ تعيد كائن العمود 10318000111 الذي حدث 
به التغيير. 

Row E‏ تعيد كائن الصف س0 8 هاه( الذي توجد به 
الخائة التي تغيرت. 

Value | 5‏ posedها P‏ تقرأ أو تغير القيمة المقترحة (التي تغيرت).. 
هذا يتيح لك لو أردت ‏ تعديل القيمة التي 














۶ العمود يتغير :ColumnChanging‏ 

ممائل للحدث السابق» ولكنه ينطلق عند محاولة إجراء التغيير في أحد أعمدة 
الجدول (أي قبل حدوث التغيير بالفعل).. ويمكنك استخدام الكود التالي لإلغاء 
تغيير قيمة الخانة: 

e.ProposedValue = e.Row(e.Column) 
لكن عليك استخدام هذه الجملة داخل شرط فلو استخدمتها هكذا بمفردها‎ 
فستمنع المستخدم من تغيير أي خانة في أي عمود في الجدول.. لهذا فالعملي‎ 
أن تستخدمها لمنع بعض القيم الخاطئة» مثل ترك عمود اسم المؤلف فارغا‎ 
لأن هذا غير مقبول في قاعدة البيانات.. وستجد هذا الكود في الفئة الجزئية‎ 
لجدول المؤلفين في مجموعة البيانات محددة النوع في المشروع‎ 
:TableAdapter 


۲۹ 














If e.Column Is AuthorColumn 0 
e.ProposedValue = "" Then 


e.ProposedValue = e.Row(e.Column) 


End If 


ويمكنك بنفس الطريقة»ء إضافة أي شروط أخرى للتأكد من صلاحية القيم التي 
يدخلها المستخدم في باقي الأعمدة. 


#2 الصف تغير :RowChanged‏ 
ينطلق بعد أن تتغيّر إحدى القيم في أحد سجلات الجدول.. والمعامل الثاني م 
لهذا الحدث من النوع ›DataRow Change EventArgs‏ وهو يمتلك 


الخاصيتين التاليتين: 
نينر | Row‏ 
بور | Action‏ 











تعيد كائن الصف س٠‏ ۸ هاه الذي توجد به الخانة 

التابعة للعمود الذي حدث به التغيير. 

تخبرك بنوع التغيير الذي حدث للصفاء وهي تعيد 

إحدى قيم المرقم 1221212014110 التالية: 

AU -‏ تمت إضافة الصف. 

- ع126161: تم حذف الصف. 

- عقمقط"): يتم تغيير إحدى قيم الصف. 

:ChangeOrigina1 -‏ تم تغيير النسخة الأصلية 
Origina1 Version‏ من السجل. 

- اقطاع 0011 متشغمع 11 ننععع مطوط"): تم تغيير النسخة 
الأصلية و0زوإم۷ 021زع02 والنسخة الحالية 
Current Version‏ من السجل. 

0mm -‏ : تم نقل التغييرات التي حدثت على 
تعاملات الصف 113252011015 إلى قاعدة البيانات 
نهائيا. 

- ع1[عة1011: تم التراجع عن التغييرات التي حدثت 
على تعاملات الصف. 

- عنط)7210: لم يحدث أي تغيير على الصف. 





#2 الصف يتغير :RowChanging‏ 
ممائل للحدث السابق» ولكئه ينطلق عند محاولة إجراء التغيير في أحد سجلات 
الجدول (قبل حدوث التغيير). 











۶۶ صف جديد للجدول :181610659120: 
ينطلق بعد استدعاء الوسيلة 7651:0187 التي تعيد سجلا جديدا من سجلات 
الجدول.. والمعامل الثاني ع لهذا الحدث من النوع 
Data ableNNewRowEventArgs‏ وهو يمتلك الخاصية سه8 التي 
تعيد كائن الصف 1034318017 الذي يمثل الصف الجديد الذي تم إنشاؤه.. هذا 
يتيح لك وضع أية قيم افتراضية تريها في خانات الصف الجديد. 


۶ تم حذف الصف 0ع)1+0171(616: 
ينطلق بعد حذف أحد سجلات الجدول.. والمعامل الثاني م لهذا الحدث من 
النوع sئChangeEventArg hata Row‏ وقد تعرفنا عليه سابقا. 
لاحظ أن هذا الحدث ينطلق والصف ما زال موجودا فعلا في مجموعة 
صفوف الجدول لکن حالته تكون (101:1171711: وهو ما سيسبب خطأ في 
البرنامج لو حاولت إضافة الصف مرة أخرى إلى الجدول!! 


# يتم حذف الصف :RowDeleting‏ 
مماثل للحدث السابق» ولكنه ينطلق عند محاولة حذف أحد سجلات الجدول 
(قبل إتمام الحذف).. والحقيقة أن هذا الحدث قليل الفائدة» لأنه لا يمتلك 
خاصية لإلغاء عملية الحذف قبل وقوعهاء وكان المنتظر أن يمتلك هذا الحدث 
الخاصية [ععمج").ء لتجعله مفيدا! 
وكل ما تستطيع فعله فيه. هو حفظ الصف الذي سيتم حذفه في متغير 
احتياطي» ليمكنك التراجع عن عملية الحذف بعد هذا لو أردت. 
لاحظ أنك لا تستطيع حذف الصف بنفسك من داخل هذا الحدث» فلو حاولت 
استخدام الوسيلة ( (ata ab1e.R ows. Re 07e). R 0w‏ لحذف الصف» 
فسيحدث خطأ في البرنامج! 
ول المع م ا SE‏ 1 
إليه الكود الذي يسأل المستخدم إن كان يريد إتمام الحذف فعلا 1 لا.. أما إن 
كنت تستخدم جدول عرضء فعليك استخدام الأحداث الخاصة به لفعل هذاء 
وإلغاء عملية الحذف إن قرر المستخدم هذا. 
أمالو كنت مصرا على استخدام هذا الحدث العقيم» فسيتوجب عليك كتابة 
بعض الكود لفعل هذا.. وقد فعلنا هذا في المشروع التعريف الجزئي لفئة 
جدول المؤلفين في المشروع 1ع1م13616»803: حيث استخدمنا الحدث 
16 المشتق من الحدث ع10اءعاء 20112‏ لسؤال 


احتياطية من جدول المؤلفين» واستخدام الوسيلة 216186 لإضافة نسخة من 
سجلات الجدول الحالي إلى الجدول الاحتياطي: 
TempTable = New AuthorsDataTable‏ 
TempTable.Merge(Me)‏ 
ثم استخدام الحدث عع 1ء ۸٠W‏ لدمج سجلات الجدول الاحتياطي بالجدول 
الأصلى مرة أخرى» وهذا سيعيد حالة السجلات كما كانت» بما فى ذلك السجل 
المحذوف: 
If TempTable IsNot Nothing AndAlso‏ 
TempTable.Count > 0 Then‏ 
Me.Merge(TempTable)‏ 
TempTable.Clear()‏ 
End If‏ 
لاحظ أن الشرط 0 < 1816.001156م3زه17 هو المؤشر الذي يشعرنا بأن 
المستخدم رفض إتمام عملية الحذف.. ولو لم نستخدمه»ء فسيتم التراجع عن 
جميع عمليات الحذف بغض النظر عن رأي المستخدم! 
والخاصية وه بالمناسبة» هي خاصية معرفة في فئة الجدول محدد النوع: 
وهي مجرد اختصار للكود التالي: 
If TempTable.Rows.Count > 0 Then‏ 
ورغم أنها تعمل بشكل صحيح» يظل بهذه الطريقة عيب خطيرء وهو 
اضطرارنا إلى نسخ كل سجلات الجدول للمحافظة على حالة سجل واحد فقط 
وهذه كارثة على الذاكرة وسرعة التنفيذ إذا كان عدد سجلات الجدول 
ضخما!.. وللأسف» الوسيلة ج6ع7»7 الخاصة بالجدول لا تقبل دمج سجل 
مقف وال تفيل الا عاتن حدر كتساملكى و ارت خا هذه المشكلة. فيك 
استخدام مجموعة بيانات احتياطية ثم استخدام الوسيلة Merge‏ الخاصة 
بمجمو عة البيانات» لأنها تقبل دمج مصفوفة من السجلات» ومن السهل وضع 
السجل المراد حذفه في مصفوفة وإرسالها إليها: 
TempDs = New DsAuthors Books‏ 
TempDs.Merge({e.Row})‏ 





تحذير هام: 
لا تعرف نسخة جديدة من المجموعة وم٥1‏ على مستوى فئة جدول 
المؤلفين.. هذا الكود غير صحيح: 
Dim TempDs As New DsAuthorsBooks‏ 
السبب في هذا أنه سيؤدي إلى تعريف دائري يعطل البرنامج عن العمل إلى 
أن يدمر كل مساحة الرصة ع1[ع510 المتاحة له في الذاكرة.. فعند تعريف 
نسخة جديدة من مجموعة البيانات 1(5411150151900[15» ستقوم بتعريف 
نسخة من جدول المؤلفين» التي ستقوم بتعريف نسخة احتياطية من 
المجموعة 1(5م1611 التي ستقوم بتعريف نسخة جديدة من جدول المؤلفين» 
التي ستقوم بتعريف نسخة احتياطية من المجموعة 110105 وهكذا إلى ما 
لا نهاية! 
وهذا نفس ما سيحدث إن استخدمت جدول مؤلفين احتياطيا وعرفت نسخة 
جديدة منه على مستوى الفئة. 
ولحل .هذه الفشكلة عراف المتفير غلى مستوى الفنة يدون الكلمة 7ه 
Dim TempDs As DsAuthors Books‏ 
ثم ضع النسخة الجديدة في هذا المتغير في الحدث ع ستتاءاء110110: 
TempDs = New DsAuthorsBooks‏ 





لكن.. لماذا لا نستخدم نرفض التغيير الذي حدث للصف المحذوف لنستعيده 
مباشرة بجملة كالتالية: 
e.Row.RejectChanges( )‏ 
فكرة جيدة» لكن هذه الطريقة ستعمل فقط مع المؤلفين القادمين من قاعدة 
البيانات» أما إذا أضاف المستخدم مؤلفاء ثم قرر حذفه» ثم ضغط [أععمة© 
لعدم إتمام عملية الحذف» فستسبب الوسيلة وعع 126160101231 خطأء لأن 
السجل المضاف يفقد كل قيمه فعليا عند حذفه!!.. هذا رغم أن هذا الصف ما 
زال موجودا في الجدول» وتستطيع أن تحصل على رقمه بالكود التالي: 
MsgBox(Me.Rows.IndexOf(e.Row))‏ 
لكن حتى لو لم يحدث هذا الخطأء > فسيؤدي إلغاء تعديلات هذا الصف المضاف 
إلى حذفه من الجدول» وهكذا لن تستعيد الصف في كل الأحوال! 
أيضاء لا يمكنك رفض تغييرات الجدول كله: 
Me.RejectChanges( )‏ 
لأن هذا سيضيع كل التعديلات التي قام بها المستخدم ولم يحفظها في قاعدة 
البيانات» كما أنه سيعيد كل السجلات التي حذفها من قبل» وليس فقط آخر 
سحل مخدر تا 











لهذا تظل طريقة مجموعة البيانات الاحتياطية أفضل وأدق طريقة يمكن 
استخدامها. 

واضح طبعا أن ميكروسوفت كانت ستحيل حياتنا إلى نعيم لو أضافت 
الخاصية 2061©).ء في هذا الحدث كما هو مألوف! 


2 تم محو الجدول :TableCl1eared‏ 
ينطلق مباشرة بعد نجاح الوسيلة ٣ج16٣‏ في محو كل سجلات الجدول» وقبل 
العودة لتنفيذ باقي الكود الذي استدعى الوسيلة ه016©.. لاحظ أن هذا الحدث 
لن ينطلق إذا حدثت أية أخطاء أثناء حذف سجلات الجدول. 
والمعامل الثاني ع لهذا الحدث من النوع «DataTableClearEventArgs‏ 
وهو يمتلك الخصائص التالية: 


Table E‏ تعيد كائن الجدول »12343181 الذي يتم 
محو سجلاته. 

2 يور TableName‏ تعيد اسم الجدول. 

53 بهن | ab] Namespace‏ | تعيد نطاق اسم الجدول. 











2 يتم محو الجدول :TableC1earing‏ 
(بعد استدعاء الوسيلة ج016 لكن قبل تنفيذها).. لاحظ أن هذا الحدث ينطلق 
دائماة حك لو گان الجدول قار غا من السجلات فعا 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 

















4 فئة مجموعة الصفوف DataRowColIlection Class‏ 


هذه الفئة ترث المجموعة ©051325ع111611211(031300116» وهي تحتوي على 
عناصر من نوع فئة صف البيانات .DataRow Class‏ 
وبخلاف ما ترثه من الفئة الأم» تمتلك هذه المجموعة الوسائل الجديدة التالية: 


# إضافة 400: 
تضيف صفا إلى مجموعة الصفوف» ولها صيغتان: 

-١‏ الصيغة الأولى تستقبل كائن الصف 1733101 الذي تريد إضافته. 

-١‏ الصيغة الثانية تستقبل مصفوفة كائنات ه۸۲۲ ٠زط0‏ تحتوي على 
القيم التي تريد وضعها في خانات السجل. . لاحظ أنك تتعامل مع 
مجموعة الصفوف من خلال كائن الجدول ©1(034312361» لهذا فان هذه 
المجموعة تعرف تركيب السجلات التي ستضيفها إليهاء وعليك مراعاة 
ترتيب الأعمدة وأنواع بياناتها عند وضعها في المصفوفة حتى لا 
يحدث خطأء وعليك كذلك ترك خانة المصفوفة المناظرة لخانة الترقيم 
التلقائي فارغة. 
وتقوم هذه الصيغة بإنشاء كائن صف جديد ووضع القيع يه a‏ 
إلى مجموعة الصفوف» وتعيد إليك كائن صف 103121507 يشير إلى 
الصف الذي تمت إضافته إلى المجموعة. 


7# تحتوي على 02621825©: 
تعيد عن[ إذا كانت مجموعة الصفوف تحتوي على السجل الذي له المفتاح 
الأساسي رم راوص" المرسل كمعامل.. ولهذا الوسيلة صيغتان: 
-١‏ الصيغة الأولى تستقبل كائنا ٤زط0‏ يحتوي على قيمة المفتاح 
الأساسي للسجل الذي تريد البحث عنه. 
- الصيغة الثانية تستقبل مصفوفة كائنات «Objects‏ تحتوي غلى قيم 
0-0 الأساسيء وذلك إذا كان المفتاح الأساسي للجدول يتكون من 


أكثر من عمود. 


- البحث عن ہ۴1 : 
مماثلة للوسيلة السابقة في صيغتيهاء إلا أنها تعيد كائن الصف س0 4۸ا54 
الذي يملك مفتاحا أساسيا مساويا للقيمة المرسلة كمعامل» وتعيد عمنطغه< إذا 


لم تعثر على الصف 

وتسبب هذه الوسيلة خطأ في البرنامج إذا لم يكن الجدول الذي تبحث فيه 
يحتوي على مفتاح أساسي.. يمكن أن يحدث هذا رغم ان الجدول الأصلي في 
قاعدة البيانات يحتوي على مفتاح أساسيء وذلك إذا استخدمت الوسيلة 1711 
لملء مجموعة البيانات» دون استخدام الوسيلة 111151602 أولاء فهي التي 
تنشيء المفتاح الأساسي في جداول مجموعة البيانات. 


الإدراج في موضع )1251:)4: 
أرسل إلى هذه الوسيلة كائن الصف 1(3212017 والموضع الذي تريد إدراجه 
فيه في مجموعة الصفوف. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


2 فئة صف البيانات DataRow Class‏ 





تتعامل هذه الفئة مع أحد صفوف الجدولء وهي لا تمتلك حدث إنشاء عاما ع11طنا2 
«Constructor‏ لهذا لا تستطيع إنشاء نسخة جديدة منها مباشرة» وبدلا من هذا 
عليك استخدام الوسيلة /1(31312516.731631901 للحصول على كائن صف جديد.. 
الحكمة من هذاء هي أن الوسيلة 71611203 تستخدم مخطط الجدول لإنشاء صف 
له نفس الأعمدة بنفس أنواع البيانات ونفس الترتيب.. والكود التالي يعرف صقا 
جديدا ويضيفه إلى جدول الكتب: 
Dim 11150015 = Ds.Tables('"'Books'"")‏ 
Dim BooksRow As DataRow = TbIBooks.NewRow( )‏ 
ThbIBooks.Rows.Add(BooksRow)‏ 


وت تمتلك هذه الفئة ١‏ لخصائص التالية: 


ف الجدول 1'2016: 
تعيد كائن الجدول 1721871216 الذي يحتوي على السجل الحالي.. تذكر أنك 
لا تستطيع إنشاء سجل جديد بدون استخدام الوسيلة 71611801 من أحد 
الجداول» لهذا حتى لو لم يكن السجل مضافا إلى مجموعة صفوف الجدول 
75 :؛ فإن هذه الخاصية ستظل تشير دائما إلى الجدول الذي تم إنشاء 
الكل الحالي تقار 


العنصر )1 

هذه هي الخاصية الافتراضية» وهي تقرأ لع 0 

خانات السجل الحالي.. لاحظ أن هذه الخاصية من النوع bjet‏ ليمكنك 

ا 5 مختلف أنواع الأعمدة. . ولهذه الخاصية الصيغ التالية: 
بعض بعض الصيغ لها معامل واحدء يستقبل اسم العمود أو رقمه» أو كائن 
e‏ 1200150 الذي يمثله.. والمثال التالي يقرأ اسم المؤلف 
الموجود في الصف الثالث في جدول المؤلفين (لا تنس أن الصف 
الأول هو الصف رقم صفر): 

Dim R = Ds.Tables('"Authors'"").Rows.Item(2) 

Dim X = R.Item(" Author") 
أو باختصار:‎ 


Dim R = Ds.Tables('"Authors'"").Rows(2) 
Dim X = R("Author") 
وهو ما يمكنك فعله في سطر واحد كالتالي:‎ 
Dim X = Ds.Tables("Authors'"").Rows(2)('"Author") 
حيث يبدو أننا نتعامل مع مجموعة الصفوف 1201/8 كأنها مصفوفة‎ 
مصفوفات» وذلك لأن الخاصية روررءغ2075.1] افتراضية؛ وكذلك‎ 
۸؛ مما يمكننا من حذف اسميهما.‎ 0W. الخاصية ۳ع[‎ 
أما لو كنت تتعامل مع مجموعة بيانات محددة النوع» فسيختصر الكود‎ 
السابق إلى:‎ 
Dim X = Ds.Authors(2)(' Author") 
أو بصورة أفضل:‎ 
Dim X = Ds.Authors(2).Author 
«DataRow Version ؟- بعض الصيغ تزيد بمعامل ثان من نوع المرقم‎ 
لتحدد من خلاله نسخة السجل التي تريد التعامل معها.. لكن هذه الصيغ‎ 
للقراءة فقط» ولا يمكن استخدامها لتغيير قيم السجل.. ويمتلك المرقم‎ 
القيم التالية:‎ Row Version 


01181 | التعاممل مع نس خة السجل الأصلية 

.Original 7 

Current‏ | التعامل مع النس خة الحالية للسجل 

.Current Version 

0560 | التعامل مع القيمة المقترحة للسجل.. هذا مفيد إذا كان 

السجل قيد التحرير ولم يتم إنهاء عملية التحرير بعد. 

وتريد قراءة القيمة الجديدة قبل قبولها ووضعها في 

.Current Version النسخة الحالية‎ 

681014 | التعامل مع النسخة الافتراضية للصفء وهي كالتالي: 

- النسخة الافتراضية للصفوف غير المعدلة هي 
النسخة الأصلية .Original Version‏ 

التسخة الأافتر:اضمية لصفو ف المتعدلة والمتضتتافة 
والمحذوفة هي النسخة الحالية .Current Version‏ 

- النسخة الافتراضية للصفوف غير المتصلة بأي 
جدول 01عطء12]:0: هي النسخة المقترحة 
.Proposed‏ 











والقيمة المستخدمة مع الصيغ التي لا تمتلك المعامل الثاني هي 10©181116. 

















انظر المثال التالي: 
عرض النسخة الأصلية ' 
MsgBox(Row(0, DataRowVersion.Original))‏ 
عرض النسخة الحالية ' 
MsgBox(Row(""' Book", DataRowVersion.Current))‏ 
عرض النسخة الافتراضية ' 
MsgBox(Row(""'Book"))‏ 


وخ مصفوفة العنصر ۸۲۲4۷ م)!: 

تعيد مصفوفة كائنات 4112337 061601 تحتوي على قيم كل خانات السجل 
الحالي بنفس ترتيب الأعمدة.. ويمكنك أن ترسل إليها مصفوفة بها القيم التي 

تريد وضعها في خانات السجل.. مثال: 
Dim TbIAuthors = Ds.Tables('Authors'")‏ 
Dim R = TblAuthors.NewRow( )‏ 
,"" ,5 ,"عنترة بن شداد" R.ItemArray = (Nothing,‏ 

Nothing}‏ ,"شاعر جاهلي" 

ThblAuthors.Rows.Add(R) 


j 57‏ به أخطاء :HasErrors‏ 
تعيد 116 إذا كانت هناك أخطاء متعلقة بالسجل الحالي.. ويمكنك معرفة 
سبب الخطأً باس تخدام الخاصية Rw ۴٣0۲‏ أو الوس يلة 
511101 م مع ملاحظة أن عليك فحص كلتيهماء لأنهما لا 

تحتويان على نفس البيانات! 


أو خطأ الصف ‘RowError‏ 
تقرأ أو تغيّر النص الذي يصف الخطأ الذي حدث في هذا الصفف.. لاحظ أن 
وضع أي نص في هذه الخاصية يغير قيمة الخاصية 1135151015 إلى True‏ 
ويجعل جدول العرض يضع أيقونة الخطأ بجوار هذا الصف. 


757 ف حالة الصف :RowState‏ 
تعيد إحدى قيم المرقم 123131807516266 التي توضح حالة السجلّ من حيث 
كونه مضافا أو محذوفا أو معدلا.. وقد تعرفنا على قيم هذا المرقم سابقا. 

كما تمثلك هذه الفئة الوسائل التالية: 


#ا> له نسخة :HasVersion‏ 
تعيد 11؛ إذا كان السجل الحالي يمتلك نسخة البيانات الموضحة في 
المعامل المرسل إلي هذه الوسيلة؛ وهو من نوع المرقم DataRow Version‏ 
الذي تعرفنا عليه من قبل. 
والمثال التالى يعرض قيمة الخانة الأولى فى نسخة السجل المقترحة إن 
e‏ : 3 
If Row.HasVersion(DataRowVersion.Proposed) Then‏ 
MsgBox(Row(0, DataRowVersion.Proposed))‏ 
End If‏ 


7# تغيير الحالة إلى مضاف 0060 5»]4: 
تغير قيمة الخاصية ع1:017:5]86 إلى 4٥ل‏ ل۸4.. وتسبب هذه الوسيلة خطأ 
في البرنامج إذا كان كانت حالة السجل تشير إلى أنه معدل.. ولحل هذه 
المشكلة» عليك استدعاء الوسيلة وعع740187عع40 أولا. 


7# تغيير الحالة إلى معدل 5600310011160: 
تغير قيمة الخاصية ع]1201512 إلى 210011560.. وتسبب هذه الوسيلة خطأ 
في البرنامج إذا كان كانت حالة السجل تشير إلى أنه معدل.. ولحل هذه 
المشكلةء« عليك استدعاء الوسيلة AcceptChanges‏ أولا. 


#ا- قبول التغييرات :AccepChanges‏ 
بوذي استدعاء هذه الوسيلة إلى شرل التقبير اكه التي حافت على الصف 
الحالي منذ أن تمّ تحميله من قاعدة البيانات» أو منذ آخر مرة تح فيها استدعاء 
الوسيلة وعع10187م6ع826,.. ليس معنى هذا أن هذه التغييرات سيتمٌ حفظها 
في قاعدة البيانات» ولكن سيت النظر إليها على أنها البيانات الأصليّة للسجل؛ 
ولن يمكنك التزاجع عنها., لاحظ أن هذه الؤسيلة تفعل ما يلي: 
- تضع القيمة Unchanged‏ في الخاصية 101751266 للسجل إذا كانت 
قيمتها تشير إلى أنه معدل أو مضاف. 
- تزيل السجل من الجدول نهائيا إذا كانت حالته تشير إلى أنه 
محذوف إع)ع]م0. 
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- تنقل القيم من النسخة الحالية 5761510 4م316" إلى النسخة الأصلية 
Version‏ 1وماع 0 للسجل. 
وعليك أن تستخدم هذه الوسيلة بحذرء حتى لا تضيع التغييرات التي حدث 
للسجل الحالي دون حفظها في الجدول الأصلي في قاعدة البيانات. 
وتسبب هذه الوسيلة خطأ في البرنامج؛ إذا حاولت استدعائها لقبول تغييرات 
ضنف لبس.مضافا إلى أي جدول] 


رفض التغييرات han ges‏ 6اع» زع1: 
يؤدي استدعاء هذه الوسيلة إلى رفض كل التغييرات التي أجريت على السجل 
الحالي» بحيث يعود إلى الحالة التي كان عليها عند تحميله من قاعدة البيانات 
أو عند آخر استخدام للوسيلة ومعمرةط٣1مءءء۸..‏ لاحظ أن هذه الوسيلة 
تفعل التالي: 
- تضع القيمة 11012860 في الخاصية 12077514216 للسجل إذا كانت 
حالته تشير إلى أنه معدل أو محذوف. 
- تزيل السجل من الجدول نهائيا إذا كانت حالته تشير إلى أنه مضاف 
.Added‏ 
- تنقل القيم من النسخة الأصلية 57615105 1081ع011 إلى النسخة 
الحالية 1761510 Current‏ للسجل. 
وتتيح لك هذه الوسيلة استعادة القيم الأصلية للسجل.. هذا مفيد في بعض 
الحالات» مثل التخلص من القيم التي سببت خطأ في السجل. 


بدأ التحرير Begin Edit‏ : 
تبدأ عمليّة تحرير الصف الحالي» وتعطل أحداث الجدول التي تنطلق عند 
حدوث تغيرات في السجلات» كما توقف عمليات التحقق من صحة البيانات 
المدخلة في كل خانة من خانات السجل» > مما يتيح للمستخدم تحرير كل خانات 

السجل بدون أي اعتراض. 
ويتم استدعاء هذه الوسيلة تلقائيا عندما يحاول المستخدم تحرير بيانات السجل 
المعروض في أدوات ربط البيانات 0014015 12318-601120 مثل مربعات 

النصوص وجدول عرض البيانات .Data6 ¡4 View‏ 
لاحظ أن السجل يحتفظ بالبيانات التي يتم إدخالها أثناء عملية التحرير في 
النسخة المقترحة .Proposed Version‏ 


إلغاء التحرير 6'22©115016: 


تلغي عمليّة التحرير التي بدأت باستدعاء الوسيلة 11016 زع186»: وتتخلص من 
نسخة السجل المقترحة «Proposed Version‏ وتحتفظ بالنسخة الحالية 
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Current Version‏ كما هي.. هذا معناه إلغاء التغييرات التي حدثت على 
السجل أثناء عملية التحرير 


2# إنهاء التحرير ٤di)‏ 3ہ :E‏ 
تنهي عمليّة التحرير التي بدأت باستدعاء الوسيلة )1101 «Begin‏ وتفحص 
القيم التي تم إدخالها في السجل أثناء وضع التحرير» فإن كانت صحيحة تقوم 
بحفظ نسخة السجل المقترحة 571510 0ع0005غ+2 في النسخة الحالية 
..urrent Version‏ هذا معناه حفظ التغييرات التي حدثت على السجل أثناء 
عملية التحرير. 
ويتم استدعاء هذه الوسيلة تلقائيا عند استدعاء الوسيلة .AcceptChanges‏ 


اح معرفة خطأ العمود :GetColumnError‏ 
تعيد نصًا يصف الخطأ الذي حدث في إحدى خانات السجل الحالي.. وتستقبل 
هذه الوسيلة معاملا يوضح العمود الذي توجد فيه هذه الخانة» سواء في صورة 
رقم العمود أو اسمه أو كائن العمود 01:2 1732 الذي يمثله. 


7# تغيير خطأ العمود :SetColumnError‏ 
تسمح لك بوضع نص يصف الخطأ الذي حدث في إحدى خانات السجلٌ 
الحالي.. ولهذه الوسيلة معاملان: 
- المعامل الأول يرضح العمود الذي توجد فيه هذه الخادة: سواء في 
صورة رقم العمود أو اسمه أو كائن العمود DataColunn‏ الذي 


- المعامل الثاني يستقبل النص الذي يشرح سبب الخطأ. 
لاحظ أن هذه الوسيلة أكثر تفصيلا من الخاصية 0W ٤۲۲٥۲‏ لأنها تحدد 
الخطأ الذي حدث في كل خانة على حدة.. وتؤدي الوسيلة 
11101 إلى وضع القيمة عنم1' في الخاصية «HasErrors‏ 
وإلى ظهور أيقونة الخطأ في جدول العرض في الخانة الناتجة من تقاطع 
الصف الحالي مع العمود الذي أرسلته كمعامل.. لكن هذه الوسيلة لا تؤثر على 
قيمة الخاصية :1:01 :101. 


#- معرفة الأعمدة التي بها أخطاء :GetColumnsInError‏ 
تعيد مصفوفة أعمدة :41335 103130001111231 تحتوي على الأعمدة التي بها 
أخطاء في السجل الحالي. 


7# محو الأخطاء :ClearErrors‏ 
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تمحو كل النصوص التي تشير إلى حدوث أخطاء في السجل.. هذا سيجعل 
الخاصية :1م1201 والوسيلة 06400111171101 تعيدان نصوصا 
فارغة. 


حذف ع6ع121: 

تضع القيمة 0ع]ء1(1 في الخاصية ع]18077512 الخاصة بالسجل الحالي.. 
هذا شخ لت ار اج هن حبنف هذا السجل بامشدعاء الوسيلة 
Reject Changes‏ أو حذفه فعلا عند استدعاء الوسيلة .AcceptChanges‏ 
لاحظ أن استخدام الوسيلة مااع[ مع سجل مضاف 
)R0w State = 40060(‏ سيؤدي إلى حذف هذا السجل في الحال. 


معرفة الصفوف التابعة :GetChild Rows‏ 
تعيد مصفوفة صفوف 417237 1031211077 بها كل السجلات المرتبطة بعلاقة 
بهذا السجل في جداول أخرى.. ولهذه الوسيلة الصيغ التالية: 

.١‏ الصيغة الأولى تستقبل كائن العلاقة 134212613610 الذي تريد 
استخدامه.. هذا ضروريء لأن السجل الحالي قد يكون له سجلات 
فرعية في أكثر من جدولء كما هو الحال في جدول الدول 
5 الذي له سجلات فرعية في جدولي المؤلفين والناشرين. 

؟. الصيغة الثانية تستقبل اسم العلاقة؛» لتبحث عنها في مجموعة العلاقات 
الفرعية 061111561361005 الخاصة بالجدول الذي يوجد به السجل 
الحالى. 

۳. الصيغتان الثالثة والرابعة مماثلتان للصيغتين السابقتين» ولكنهما تزيدان 
بمعامل ثان من نوع المرقم 1510ء/1031312071» ليمكنك من خلاله 
اختيار نسخة السجلات ۷615101۸ التي تريد قراءتها من الجدول 
الفرعي. 


تغيير الصف الرئيسي 21612612018 561]12: 

أرسل إلى هذه الوسيلة كائن السجل 1234819018 الذي تريد جعله السجل 
الرئيسي Master‏ للسجل الحالي.. لاحظ أن السجل الرئيسي يمكن أن يكون 
في جدول آخر (الجدول الرئيسي): أو أن يكون في الجدول الحالي 
(علاقة ذاتية .(Self Relation‏ 

وتوجد صيغة أخرى لهذه الوسيلةء تزيد على الصيغة السابقة بمعامل ثان» 
يستقبل كائن العلاقة 1734210612610 الذي يربط بين السجلين. 

ويمكنك استخدام هذه الوسيلة إذا أردت تصحيح خطا في الجدول الفرعي» كأن 
تغير مؤلف أحد الكتب بعد نسبته خطأ إلى مؤلف آخر.. وفي هذه الحالة كل ما 
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ستفعله هذه الوسيلة» هي وضع قيمة المفتاح الرئيسي 5 للمؤلف»› في خانة 
المفتاح الفرعي (4110111, للكتاب. 


معرفة الصف الرئيسي 2112112036 :GetP‏ 

تعد الس ار تسى الذي يرتيظ يه الس لحان با ليذه الوسيلة هدة 
بعض الصيغ تستقبل معاملا واحداء هو العلاقة التي يشترك فيها 
السجل الحالي» سواء في صورة اسم العلاقة؛ أو كائن العلاقة 
.DataRelation‏ 
0 البيمكنك من خلاله تحديد النسخة 176125100 
التي تريد قر انها من التتجل الرثيددي 


معرفة الصفوف الرئيسية :Get°a4r e)۸ 0 ws‏ 
DataRow Array‏ 3 تحتوي على كل ا الز اة التي ند تشير إلى 
السجل الحالي. . في الحقيقة لا تبدو لهذه الوسيلة أية أهمية حالياء فهي دائنا 
تعيد سجلا رئيسيا واحداء وهذا يجعل استخدام الوسيلة GetParentRow‏ 

أكثر منطقية! 


هل هي عدم 15100111: 
تعيد عن:1' إذا كانت الخانة الموجودة في السجل الحالي والعمود المرسل 
0 فار غة 1(111111.. ولهذه الوسيلة الصيغ التالية: 
بعض الصيغ لها معامل واحدء يستقبل اسم العمود أو رقمه أو كائن 
ا hatm‏ الذي يمثله. 
؟- وهناك صيغ لها معامل تان من نوع المرقم «DataRow Version‏ 
ليمكنك من خلاله تحديد النسخة مدوم التي تريد فحص قيمها. 


4 فئة مجموعة الأعمدة DataColumnColIlection Class‏ 


هذه الفئة ترث المجموعة 111611211(0313001162010513256» وهي تحتوي على 
عناصر من نوع فئة عمود البيانات .DataColumn Class‏ 

ولا تملك هذه المجموعة أية خصائص أو وسائل جديدة غير ما ترثه من الفئة الأمء 
ولكن بعض هذه العناصر يحتاج منا إلى وقفة: 
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7 ف العنصر دررء16: 
تعيد كائن عمود البيانات 12230011 الموجود في المجموعة بناء على 
المعامل المرسل إليها.. ولهذه الوسيلة صيغتان: 
-١‏ الصيغة الأولى تستقبل رقم الخانة التي يوجد بها العمود في 
المجموعة.. لاحظ أن خطأ سيحدث لو أرسلت رقم خانة غير موجودة 
في المجموعة. 
۲- والصيغة الثانية تستقبل نصا يمثل اسم العمود في الجدول» ليتم البحث 
عنه في المجموعة» فإن كان موجودا تعيد هذه الوسيلة كائن العمود 
الذي يمثله» وإن لم يكن موجودا فإنها تعيد عمزط)710 ولا يحدث خطأ. 


# إضافة 400: 
تضيف عمودا إلى مجموعة الأعمدة» مع ملاحظة أن الأعمدة التي تضيفها إلى 
مجموعة البيانات هي أعمدة مؤقتة خاصة بالبرنامج فقطء ولا تظهر في قاعدة 
البيانات» حتى بعد إجراء عملية التحديث ع110036].. لكن لو كنت تحتاج إلى 
إنشائها في قاعدة البيانات» فعليك باستخدام أوامر 501 الخاصة بإنشاء أعمدة 
تناظر الأعمدة الجديدة التى أضفتها فى مجموعة البيانات. 
وتمتلك هذه الوسيلة الصيغ التالية: ٠‏ 

-١‏ الصيغة الأولى بدون معاملات» وهي تنشئ عمودا جديدا بالاسم 
الافتراضي (01021© أو 2مدصد[ه0© ... إلخ).. لاحظ أن هذا العمود 
سيتعامل مع بيانات نصية ع510110. 

؟- الصيغة الثانية تستقبل كائن العمود 103130001111 وتضيفه إلى 
المجموعة. 

۳- الصيغة الثالثة تستقبل اسم العمودء وتقوم بإنشائه وإضافته إلى 
المجموعة.. وتستطيع إرسال نص فارغ إلى هذه الوسيلةء لإنشاء عمود 
له الاسم الافتراضي (221د01© أو 2صصuاه‏ ... إلخ). 

-٤‏ الصيغة الرابعة تزيد على الصيغة السابقة بمعامل تان من نوع فئة 
النوع عم150: ليمكنك من خلاله تحديد نوع بيانات العمود.. لاحظ أن 
نوع العمود يعتبر نصيا ع5 في الصيغ التي لا تستقبل هذا المعامل. 

-٥‏ الصيغة الخامسة تزيد على الصيغة السابقة بمعامل ثالث» يستقبل نصا 
يمثل الصيغة التي ستوضع في الخاصية 165510م1:2 الخاصة 
بالعمودء ممايتيح لك إنشاء عمود محسوب 
Column‏ 0231011123660).. وسنتعرف على هذه الخاصية عند التعرف 
على فئة عمود البيانات .Data Column‏ 
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لاحظ أن هذه الصيغ تعيد كائن العمود 173180011111 الذي أضيف إلى 
مجموعة الأعمدة» ما عدا الصيغة الثانية فأنت ترسل إليها كائن العمود بالفعل 
لهذا ليست لها قيمة عائدة. 

ويمكنك إضافة الأعمدة إلى هذه المجموعة بطريقة مرئية في وقت التصميم» 
وذلك من خلال نافذة خصائص الجدول.. لفعل هذا يجب أن يكون لديك كائن 
جدول في صينية مكونات النموذج (وهذا غير شائع)» أو يمكنك استخدام 
مجموعة بيانات عادية ]1031356 112-1560 موضوعة في صينية 
المكونات» فلو عرضت خصائصها في نافذة الخصائصء فسيمكنك استخدام 
الخاصية و1261 لعرض محرر مجموعة الجداول» ولو حددت أي جدول في 
هذه المجموعةء فستظهر خصائصه في القسم الأيمن من النافذة» وستجد بينها 
الخاصية ورزرون:[ه0).. ولو ضغطت زر الانتقال الموجود في خانة هذه 
الخاصيةء فستظهر نافذة محرر مجموعة الأعمدة» كما في الصورة: 


Columns Collection Editor × 





Members: Columni Properties: 
0 capt Columnt اه‎ 
ناه عرزن الام‎ 
DataTypê System, String 
DateTineMode Uns pecifiedlLocal 
Defauk\alue *OBNuli 
Fxprescian 
MarLength 1 
Narespace 
Prelit 
ResclOnly Fale 
Unique false 
E Deslgh 
[Nama] DataColumn1l 
“يونا سا0‎ TIue 
x Modifiers Friend 
7 Misc 
Add | colimnMnpprr) Flement 2 
Close 


في هذه النافذة يمكنك ضغط الزر Add‏ لإضافة عمود جدید» حيث ستظهر 
خصائص هذا العمود في القسم الأيمن» ويمكنك تغييرها كما تشاء. 


7# موضع العمود 12016:01: 


تبحث عن العمود المرسل إليها كمعامل في مجموعة الأعمدة» وتعيد رقم 
الخانة التي يوجد بها في المجموعة:. أو تعيد ١-‏ إن لم يكن موجودا.. ولهذه 
الوسيلة صيغتان: 

-١‏ الصيغة الأولى تستقبل اسم العمود. 
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؟- والصيغة الثانية تستقبل كائن العمود 102120011::11. 


7# يمكن حذفه :Can Remove‏ 
تعيد 116 إذا كان من الممكن حذف كائن العمود 103130001111 المرسل 
كمعامل من مجموعة الأعمدة.. وتعيد هذه الوسيلة 72156 إذا لم يكن العمود 

موجودا في المجموعة. أو إذا كان داخلا في علاقة. 


#> حذف :Remove‏ 
تحذف العمود المرسل إليها كمعامل من مجموعة الأعمدة.. ولهذه الوسيلة 
صيغتان: 
-١‏ الصيغة الأولى تستقبل اسم العمود. 
"- والصيغة الثانية تستقبل كائن العمود ود uںآه۸€†م5.‏ 


كما تمتلك مجموعة الأعمدة الحدث التالي: 


المجموعة تغيرت :CollectionChanged‏ 
ينطلق عندما يتغير عدد الأعمدة» سواء بالحذف أو الإضافة. 
والمعامل الثاني م لهذا الحدث من النوع CollectionChangeEventArgs‏ 
الذي تعرفنا عليه من قبل في مجموعة الجداول .DataTableCollection‏ 
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4 فئة عمود البيانات Class‏ 102426001111111 


تمثل هد الففة مخطط أحد أعمدة الجدول» وهي ترث الفئة 
»Marsha]ByValueComponent‏ مما يتيح لك إضافتها إلى صينية مكونات 
النموذج» وإن كان عليك أن تضيفها أولا إلى صندوق الأدوات. 

ولحدث إنشاء هذه الفئة نفس صيغ الوسيلة 400 الخاصة بمجموعة الأعمدة 
1+ م ا عدا الصيغة الثانية.. كما توجد صيغة إضافية 
لحدث الإنشاء» تستقبل المعاملات التالية بالترتيب: 


اسم العمود. 

كائن نوع 4ع06[6 6م157» يحتوي على نوع بيانات العمود. 

صيغة العمود التي ستوضع في الخاصية 165910م2:2 التي سنتعرف عليها 
بعد قليل. 

إحدى قيم المرقم عءم157 18م م223 لتوضع في الخاصية 
1-5 الخاصة بالعمود» وسنتعرف عليها بعد قليل. 


والمثال التالي يعرف عمودا نصيا اسمه Temp‏ ويضيفه إلى جدول الكتب في 
مجمو عه هة البيانات التي تحمل الاسم Ds‏ 
Dim Clmn As New DataColumn('Temp", GetType(String))‏ 


Ds.Tables("'"Books'"").Columns.Add(Clmn) 


وكنتلك فة الغموة الصاتضن القالنة: 


فط الجدول ع1'21: 


تعيد كائن الجدول 1031213616 الذي ينتمي إليه هذا العمود. 


:ColumnName وخ‎ 


3 نطاق الاسم :Namespace‏ 


تقرأ أو تغير نطاق الاسم الخاص بالجدول الذي ينتمي إليه العمود. 


ونج البادئة عرزاعمرم: 


تقرأ أو تغير البادئة التي تمثل نطاق اسم الجدول الذي ينتمي إليه العمود. 


5 زوز الرتبة اومذdإ0:‏ 


تعيد عددا صحيحا يمثل ترتيب العمود في مجموعة الأعمدة. 
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3 العنوان 10)م2©: 
تقرأ أو تغير عنوان العمود.. من المفروض أن يتم عرض هذا العنوان بدلا 
من اسم العمود في أدوات ربط البيانات 04:015© ›Data-Bound‏ لكنك لو 
جربت هذا مع جدول العرض مثلاء فلن تجد له تأثيرا!.. يبدو أن عليك ربط 
أداة العرض حصريا بهذه الخاصية» لكي ترى تأثيرهاء كما سنرى لاحقا. 


وخ نوع البيانات 1226317:06: 
تفرأ أو تغير كائن النوع 6عءع[06 مءمرآ الذي يمثل نوع بيانات العمود. 


وخا القيمة الافتراضية 12612111)5721016: 
تقرأ أو تغير القيمة الافتراضيّة لخانات العمود.. يمكنك مثلا أن تضع الرقم 
صفر في هذه الخاصية إذا كنت تتعامل مع عمودي رقمي. 


الماح بالعدم 1837111 41101910: 
إذا جعلت قيمة هذه الخاصية ع1::]'» فسيسمح بترك بعض خانات هذا العمود 
فارغة .DbNull‏ 


وخ أقصى طول :MaxLength‏ 
تقرأ أو ت تغير أقصى عدد من الحروف يمكنك كتابته في العمود الذي يتعامل 
مع يداداك ا . والقيمة الافتراضية لهذه الخاصية ١-‏ مما يعني عدم وجود 
قيود على عدد الحروف. . لاحظ أن قيمة هذه الخاصية سيتم تجاهلها إذا كان 
العمود يتعامل مع بيانات من نوع آخر غير النصوص. 


وخ للقراءة فقط 'و206©(2[1»ع12: 
إذا جعلت قيمة هذه الخاصيّة م1٠‏ فلن يمكنك تغيير قيمة أي خانة في هذا 
العمود بعد إضافة الصف الذي توجد به إلى الجدول.. لاحظ أن جعل قيمة هذه 
الخاصية عuآ]‏ مع عمود يحمل ناتج عملية حساية 
موضوعة في الخاصية 1655101م17» سيؤدي إلى حدوث خطأ في البرنامج» 
لأن تغيير قيمة أي خانة في عمود داخل في العملية الحسابية سيؤدي تلقائيا 
إلى إعادة حساب قيمة ة الخانة المناظرة في عمود الناتج. 


وخ متفرد ©101011آ: 
إذا جعلت قيمة هذه الخاصيّة مںإ]» فلن يسمح بتكرار قيم خانات هذا العمود. 
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وخ ترقيم تلقائي :AutoIncrement‏ 
إذااحطف فة هدم الخاضتة روآ ف ف خانات هذا الود اا 
كلما تمت إضافة صف جديد إلى الجدول.. لاحظ أن عمود الترقيم التلقائي 
يعون للقراءة فقط «ReadOnly‏ ولا يمكنك تغيير قيمته بنفسك.. والقيمة 
الافتراضية لهذه الخاصية هي ع1"815. 


وخ بذرة الترقيم التلقائي :Auto[ncrementSeed‏ 
تحدد رقم بدء الترقيم في عمود الترقيم التلقائي.. والقيمة الافتراضية هي .١‏ 


3 خطوة الترقيم التلقائي :AutolncrementStep‏ 
تحذد مقدار الزيادة في عمود الترقيم التلقائي.. والقيمة الافتراضية هي .١‏ 


7 ف الخصائص الإضافية :Extended Properties‏ 
تعيد مجمو عة الخصائص ١0٥1ء‏ 1اه ٣رااممهإ۴‏ التي تحتوي على 
الخضائصن الإحاقتة رة وهي عا لتلك ااا كان الول 


وخ خريطة العمود :ColumnMapping‏ 
تحدد كيف يتم تمثيل العمود في كود ۷1× عند حفظ الجدول» وهي تأخذ 
إحدى قيم المرقم عم157عطامم713 التالية: 


Element 


Attribute 


SimpleContent 


Hidden 








حفظ العمودين (11 و ۲ه طا ں۸ في جدول المؤلفين: 


<Authors> 
<ID>1</ID> 
<Autho!إ>‎ = توفيق الحكيم'‎ 
</ Authors> 
يتم تمثيل العمود كسمة [>.. هكذا متلا سيتم حفظ‎ 


العمود (11: 
<“'توفيق الحكيم' = <Authors ID=1 Author‏ 
</اشهر زاد' = <Book ID=1 Book‏ 
</Authors>‏ 
يتم تمثيل العمود كفرع من نوع الفئة غ2 711مكة.. هذا 
الموضوع خارج نطاق هذا الكتاب. 
هذا العمود خفي» ويستخدم في البناء الداخلى للجدول: 





006 

















البيانات. 








وخ نظام التاريخ والوقت :Date ¡1n eM 0de‏ 
تحدد نظام التوقيت المستخدم مع هذا الجدول؛ إذا كان نوع بياناته تاريخ أو 
وقت.. وتأخذ هذه الخاصية إحدى قيم المرقم ©1127 ع122256141021 التالية: 


Local‏ التعامل بالتاريخ المحلي للجهاز الذي يوجد عليه 
الإرقامج. 
Ute‏ التعامل بالتاريخ العالمي. 


Unspecified‏ غير محدد. 
21ء0 Unspecified‏ توقيت محلي غير محدد.. هذه هي القيمة 
الافتراضية. 











لاحظ أنك لا تستطيع تغيير قيمة هذه الخاصية بعد إضافة الخانات إلى العمودء 
إلا في حالة واحدة: إذا كنت تحول من القيمة Unspecified‏ إلى 
Unspecified Local‏ أو العكس. 


وخ التعبير :Expression‏ 
تقرأ أو تغير الصيغة النصية للعمود» والتي يمكن استخدامها فيما يلي: 
- حساب قيم خانات العمود الحالي» من ناتج عملية حسابية على أعمدة 
أخرى» وفي هذه الحالة ييسمى بالعمود المحسوب 
.Calculated Column‏ 
1.5161 بعد ذلك للحصول على السجلات التي حققت 
هذا الشرطء. وسنرى مثالا على هذا بعد قليل. 
والجدول التالى يلخص لك المعاملات والدوالٌ التى يمكنك استخدامها لتكوين 
صيغة العمود: 1 
المعاملات يمكنك استخدام المعاملات الحسابية التالية على الأعمدة: 
الحسابية الجمع: c+‏ الطرح: -« الضرب *» القسمة /»› باقي 
القسمة %.. مثال: 
Col.Expression = "Price * Copies_No"‏ 
المعاملات يمنكن استخدام المعاملات المنطقية التالية بين الأعمدة: 
المنطقية AND, OR, NOT‏ 
والمثال التالي يرى إن كان اسم الكتاب يبدأ بحرف يسبق 
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معاملات المقارنة 





الميم أبجدياء وأن الكتاب للمؤلف رقم :٤‏ 
Col.Expression =‏ 
And AuthorID = 4"‏ 'م' < "Book‏ 
لاحظ أن التعبير السابق سيضع في خانات العمود 16 
أو ع115» مما يسمح لك باستخدام الوسيلة S1‏ 
الخاصة بكائن الجدول لاختيار الصفوف التي تحقق أو 
لا تحقق شرطا معينا.. اعتبر أن العمود في المثال 
السايق اسمة أو هذا المثال يحصبل على الضفو 
التي تحقق الشرط السابق: 
Dim R( ) As 2140777‏ 
R = T.Select ("Col = True")‏ 
يمكنك استخدام معاملات المقارنة التالية: 
IN LIKE‏ =< => < > >< = 
بنفس الطريقة التي تعرفنا عليها عند شرح جمل ا@8S»›‏ 
مع ملاحظ أن علامات التعويض (* أو %) غير 
مسموح بها في منتصف التعبير المستخدم مع الدالة 
1117 ]. مثلاء التعبير التالي غير مقبول: 
" 'أحمد*توفيق' "Author Like‏ 
لكن يمكن استخدام علامات التعويض في بداية النص أو 
نهايته.. مثال: 
" 'هيكل*' "Author Like‏ 
" '*#هيكل' "Author Like‏ 
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CONVERT 


LEN 


ISNULL 


TRIM 


SUBSTRING 


IF 





تقوم بالتحويل بين أنواع البيانات.. مثال: 
Col.Expression =‏ 
"Convert(ID, 'System.Int32')"‏ 
تعيد طول النص الموجود في خانات العمود.. والمثال 
التالي سيجعل العمود 01) يعرض طول أسماء الكتب 
الموجودة في العمود 00g)‏ 8: 
Col.Expression = "Len(Book)"‏ 
لاحظ أتك غير مجبر على قصر معامل هذه الدالة 
(والدوال التالية أيضا) على اسم أحد حقول الجدول.. إن 
تعبيرا كهذا متاح أيضا: 
Col.Expression = "Len(Book + Author)"‏ 
ولا تحاول استخدام العلامة "8" لتشبيك النصوص» 
فهي غير متاحة هنا.. استخدم بدلا منها علامة الجمع 
0 
تستقبل هذه الدالة معاملين: اسم العمودء وقيمة 
افتراضية.. وتفحص هذه الدالة العمودء فإن وجدت فيه 
قيمة أعادتهاء وإن وجدته فارغا أعادت القيمة 
الافتراضسية.. المثال التالي يعية قيسة العمود 
uth‏ أو ١١‏ إذا كان فارغا: 
Col.Expression = "IsNull(AuthorID, -1)"‏ 
تزيل المسافات من بداية ونهاية خانات الحقل المرسل 
إليها كمعامل.. مثال: 
Col.Expression = "TRIM(AuthorID)""‏ 
تعية عا هن اضر الموحود فن كانات الود المر ن 
إليهاكمعامل» بدءا من الحرف المذكور رقمه في 
المعامل الثاني» وبالطول المحدّد في المعامل الثالث.. 
(مماثلة للدالة ع1غ115ك.ع 0 5).. مثال: 
Col.Expression =‏ 
"SUBSTRING(Book, 2, 8)"‏ 
تأخذ هذه الدالة ثلاثة معاملات: 
- الأول شرط سيتمٌ التحقق منه. 
- والثاني هو القيمة المعادة إذا كان الشرط صحيحا. 
- والثالث هو القيمة المعادة إذا كان الشرط خاطنا. 
مثال: = Col.Expression‏ 
"('رخيص' ,'غال' "IIF(LEN(Price)>10),‏ 
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Parent 


Child 


دوال التجميع 





تشير إلى الجدول الرئيسي الذي يدخل في علاقة مع 
الجدول الحالي.. افترض أن المتغير ٥01‏ يتعامل مع 
عمود في جدول الكتب.. المثال التالي يضع في هذا 
العمود طول اسم كل مؤلف: 
Col.Expression = "LEN(Parent. Author)"‏ 
وإذا كان الجدول مشتركا في أكثر من علاقة مع جداول 
رئيسية اخرىء فيمكنك أن ترسل اسم العلاقة بين قوسين 
بعد الكلمة عررعرجح2 كالتالي: 
Col.Expression =‏ 
"LEN(Parent(Authors Books).Author)""‏ 
تشير إلى الجدول الثانوي المرتبط بالجدول الحالي 
بعلاقة, حيث تستخدم المفتاح الأساسي Primary Key‏ 
لكل سجل في الجدول الرئيسيء للحصول على السجلات 
الفرعية المرتبطة بهذا المفتاح في الجدول الفرعي.. 
ونظرا لأن ناتج هذه الدالة قد يكون أكثر من سجلء فلا 
يمكن استخدامها بمفردهاء وإنما تستخدم مع إحدى دوال 
والمثال التالي يضيف عمودا إلى جدول المؤلفين» 
يعرض عدد الكتب التي ألفها كلّ مؤلف: 
Dim Col As New DataColumn(‏ 
GetType(Integer))‏ ,"1100115001" 
Col.Expression = "Count(Child.AuthorID)"‏ 
Ds.Tables(" Authors'").Columns.Add(Col)‏ 
ولو كان الجدول داخلا في أكثر من علاقةء فيمكنك 
إرسال اسم العلاقة كمعامل إلى التعبير 01110» مثل: 
Col.Expression =‏ 
"Count(Child(AuthorsBooks).AuthorID)""‏ 
يمكنك استخدام دوال التجميع التالية: 
Sum, Avg, Min, Max, Count, StDev, Var‏ 
لاحظ أن استخدام هذه الدوال على العمود الحالي 
سيجعلها تتعامل مع كل الصفوف بدون تقسيمها إلى 
مجمو عات عمامںه]6.. متلاء لو استخدمت التعبير: 
"Count )Author1D("‏ في جدول الكتب فسيعيد عدد 
صفوف جدول الكتب.. ولو أردت تجميع الصفوف التي 
تتسابه في قيمة عمود معينء فعليك استخدام التعبير 
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4 للاستفادة من العلاقة بين جدولين في تجميع 
الصفوف التي تتشابه في المفتاح الرئيسي.. ولو 
استخدمت التعبير: "Count (Child.Author1D)"‏ 
في جدول المؤلفين» فستحصل على مجموع كتب كل 








مؤلف. 
r‏ حرف نهاية السطر. 
\n‏ حرف بداية السطر. 
\t‏ علامة جدولة 180. 
لاحظ أن عليك وضع النصوص والتواريخ بين العلامتين ' ' مثل: 
'طويل' 
' 1/1/2009" 
كما يمكن وضع التواريخ بين العلامتين # #» مثل: 
#1/1/2009# 


ويمتلك كائن العمود الوسيلة التالية: 


#ا- تغيير الرتبة 01581 56)01: 

أرسل إلى هذه الوسيلة عددا صحيحاء يمثل الموضع الجديد الذي تريد أن 
يصير العمود فيه في مجموعة الأعمدة.. هذا هو الحل الوحيد لتغيير موضع 
العمودء لأن مجموعة الأعمدة لا تحتوي على الوسيلة +10561.. وقد استخدمنا 
هذه الوسيلة في الزر "حفظ البيانات ؟" في المشروع Custom DataSet‏ 
لجعلزل العم و غ516 ف يالموضع رقم ” 
(العمود الثالث) بعد إعادة إضافته إلى الجدول.. لاحظ أن هذا سيغير ترتيب 
العمود في الجدول» لكنه سيظهر في جدول العرض كآخر عمود!.. هذا لا 
يؤثر في عمل البرنامج» لكنه يزعج المستخدم, لهذا عليك تغيير ترتيب عرض 
العمود في جدول العرض أيضا.. هذا هو سبب استخدامنا للجملة التالية في 
نهاية الإجراء :ShowGrades‏ 

GradesCols@2).DisplayIndex = 0‏ 
هذه الجملة تجعلنا واثقين أن العمود الذي يعرض اسم المادة يظهر دائما قبل 
العمود الذي يعرض درجات الطالب. 


4 فئة قارئ جدول البيانات Data TableReader Class‏ 


حكن 




















هذه الفئة ترث فئة قارئ البيانات الأم 1255© ل2 Rه†Dط0›‏ وهي تشبه قارئ 
البيانات العادي في طريقة عملهاء لكنها لا تستخدم كائن أمر للحصول على السجلات 
من قاعدة البيانات» فهي تقرأ السجالات من جداول مجمو عه هة البيانات مباشرة. 
ولإنشاء قارئ بيانات يقرأ سجلات أحد الجداول» عليك باستخدام الوسيلة 
601 الخاصة بهذا الجدول كالتالي: 
Dim Tr = Ds.Tables('"Authors'").CreateDataReader‏ 
Do While Tr.Read‏ 
MsgBox(Tr("ID"))‏ 
MsgBox(Tr("'Author'"))‏ 
Loop‏ 
ولإنشاء قارئ بيانات يقرأ سجلات كل الجداول»ء عليك باستخدام الوسيلة 
1 الخاصة بمجموعة البيانات ٥5وج(‏ كالتالي: 
Dim Tr = Ds.CreateDataReader‏ 
Do‏ 
Do While Tr.Read‏ 
Dim RowTxt As String = ""‏ 
For I = 0 To Tr.FieldCount - 1‏ 
RowTxt &= Tr.GetName(l) + " = " +‏ 
Tr(D).ToString( ) + vbCrLf‏ 
Next‏ 
MsgBox(RowTxt)‏ 
Loop‏ 
Loop While Tr.NextResult‏ 
لاحظ استخدامنا للوسيلة 716412651016 للانتقال من سجلات أحد الجداول إلى 
سجلات الجدول التالي.. لاحظ أيضا أننا لم نستخدم أسماء الأعمدة عند قراءة 
خانات كل سجل» وذلك لأن السجللات ستختلف من جدول إلى آخر في عدد الأعمدة 
وأسمائها.. وبدلا من هذا استخدمنا الخاصية 716101001104 لإنشاء حلقة تكرار تمر 
عبر كل الأعمدة» لقراءة كل خانة باستخدام رقم العمود بدلا من اسمه. 
ويمكنك تجربة هذا الكود في المشروع .DataTableReaderSample‏ 
ولحدث إنشاء الفئة 123121361612620 الصيغتان التاليتين: 
-١‏ الأولى تستقبل كائن الجدول 12381216 الذي ستقرأ سجلاته. 
؟- والثانية تستقبل مصفوفة جداول /41383 12321816 لتقرأ سجلاتها. 
ولا تمتلك هذه الفئة أية خصائص أو وسائل جديدة غير ما ترثه من الفئة الأم. 


4 فئة مجموعة العلاقات 
DataRelation Collection Class‏ 


۳۷1 


هذه الفئة ترث الفئة ©ع111611211(31300116011001325» وهي تحتوي على كائنات 
من نوع فئة علاقة البيانات .DataRelation Class‏ 

وتمتلك هذه الفئة الخصائص والوسائل الشهيرة للمجموعات 5م20اء»0011» 
ومعظمها يستخدم اسم العلاقة كمعامل» أو يستخدم كائن العلاقة 102121612610 
الذي يمثلها.. لهذا نحتاج هنا إلى التركيز على العناصر التالية فقط: 


57 لز العنصر ہ)٤!:‏ 
هذه هي الخاصية الافتراضيةء وهي تستقبل اسم العلاقة كمعامل أو رقم 
العلاقة في المجموعة» وتعيد إليك كائن العلاقة م1(34312613610 الذي يمثلها.. 
وقد استخدمنا هذه الخاصية في المشروع 1034356100016115: للحصول 
على كائن العلاقة التي يضغط المستخدم اسمها في قائمة العلاقات» لنعرض 
خصائصها في مربع رسالة. 


7# إضافة 400: 
تضيف علاقة إلى المجموعة» ولها الصيغ التالية: 

-١‏ الصيغة الأولى تستقبل كائن العلاقة 172343161340 المراد إضافته. 

-١‏ الصيغة الثانية تستقبل معاملين من النوع ا1(3800011» يمثلان 
الحقل الرئيسي والحقل الفرعي على الترتيب» حيث سيتم إنشاء علاقة 
بينهماء وإضافتها إلى المجموعة. 

۳- الصيغة الثالثة مماثلة للصيغة السابقة» إلا أنها تستقبل مصفوفتين من 
النوع 12001100 : وذلك لمراعاة الحالة التي يتكون فيها كل من 
المفتاح الأساسي والفرعي من أكثر من عمود. 

-٤‏ الصيغة الرابعة تستقبل ثلاثة معاملات: اسم العلاقة» وكائن العمود 
الرئيسي» وكائن العمود الفرعي. 


VY 


5- الصيغة الخامسة تزيد بمعامل منطقى على الصيغة السابقةء إذا جعلت 
قيمته 170156 فلن يتم إنشاء قيود عند إنشاء العلاقة.. والقيمة 
الافتراضية في الصيغ التي لا تحتوي هذا المعامل هي عد1» لهذا يتم 
إنشاء قيد التفرد 171011600151114 على الحقل الأساسي إن لم يكن 
موجوداء وإنشاء قيد المفتاح الفرعي ForeignKeyConstraint‏ على 
الحقل الفرعي إن لم يكن موجوداء ويتم إضافتهما إلى قيود الجدول. 

"”- الصيغة السادسة مماثلة للصيغة السابقةء إلا أن معامليها الثاني والثالث 


يستقبلان مصفوفة حقول 11037 at4C0lumnط‏ لمراعاة الحالة التي 
يتكون فيها كل من المفتاحين الأساسي والفرعي من أكثر من حقل. 


لاحظ أن جميع الصيغ ‏ ما عدا الأولى ‏ تعيد كائن العلاقة DataRelation‏ 
الذي ثم (نشاوء وإضيافقته إلينالمجموغة 


۶ المجموعة تغيرت :CoIlectionChanged‏ 
أو الإأضافة.. والمعامل الثاني م لهذا الحدث من النوع 
15ل غطء 2817 الذي تعرفنا عليه من قبل في مجموعة 
الجداول .DataTableCol1lection‏ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


مدر 


DataRelation Class فئة العلاقة‎ 4 


تحتوي هذه الفئة على تفاصيل العلاقة المنشأة بين جدولين. 
ولحدث إنشاء هذه الفئة نفس صيغ الوسيلة DataRelationCollecti01.Add‏ ما 
عدا الصيغة الأولى التي تستقبل كائن علاقة.. وإضافة إلى هذه الصيغ»ء يمتلك حدث 
الإنشاء الصيغتين الجديدتين التاليتين: 

-١‏ الصيغة الأولى تستقبل المعاملات التالية: 


نصا يمثل اسم العلاقة. 

نضا يمال :انس اتددول ار صي 

نضا يكل ابم الجذول الفر حي 

مضق ف سو لحري على اسا عبدة اقام ااي 

مصفوفة نصية تحتوي على أسماء أعمدة المفتاح الفرعي. 

معاملا منطقيا مجع ۰8001 لتوضع قيمته في الخاصية إعNest‏ 
الخاصة بكائن العلاقة. 


لاك الضبيعة ا تتفل ا 


نضا بل اسم العلاكة, 

نصا يمثل اسم الجدول الرئيسي. 

نصا يمثل نطاق اسم عع2م7135065 الجدول الرئيسي. 

نضا بهشل اسم الجذول الفرعي 

تضصا يمل طاق اس الجذول الغ 

مصفوفة نصية تحتوي على أسماء أعمدة المفتاح الأساسي. 

مصفوفة نصية تحتوي على أسماء أعمدة المفتاح الفرعي. 

معاملا منطقيا رهع[800› لتوضع قيمته في الخاصية Nested‏ 
الخاصة بكائن العلاقة. 


والمثال التالي يريك كيف تنشئ علاقة بين الحقل (11 في جدول المؤلفين» والحقل 
0ا في جدول الكتب: 


Dim ID As DataColumn = _ 
Ds.Tables('"Authors'").Columns("ID") 

Dim AuthorID As DataColumn = _ 
Ds.Tables('"'Books'").Columns("AuthorID") 


Dim R As New DataRelation("AuthorsBooks'", ID, AuthorID) 


۲۷۹ 


لاحظ أن هذه العلاقة لم توضع في مجموعة البيانات 1238564 إلى الآنء لهذا 
عليك إضافتها إلى مجموعة العلاقات بنفسك كالتالي: 

Ds.Relations.Add(R) 
وعد ك الخ الأخيرف تضاف هذه العلاقة لقانيا إلى مج عة العلاقات‎ 
الرئيسية 2316126136105 لجدول المؤلفين» ومجموعة العلاقات الفرعية‎ 
لجدول الكتب.‎ 5 


وتمتلك فئة العلاقة الخصائص التالية: 


# فط مجموعة البيانات 12262561: 
تعيد كائن مجموعة البيانات +1ع1(21256» الذي تنتمي إليه هذه العلاقة. 


وخا اسم العلاقة :RelationName‏ 


تقرأ أو تغيّر اسم العلاقة. 


7 ف الجدول الرئيسي 22161211'2116: 
تعيد كائن جدول 1232818516 يمثل الجدول الرئيسي في هذه العلاقة. 


7 ف الجدول الفرعي 111071'21216'): 
تعيد كائن جدول 10324312316 يمثل الجدول الثانوي في هذه العلاقة. 


57 ف الأعمدة الرئيسية :ParentColumns‏ 
تعيد مصفوفة من النوع :10312000111 تحتوي على الأعمدة الرئيسيّة في 
هذه العلاقة. 


“5 ف الأعمدة الفرعية رص uاه4€اChi:‏ 
تعيد مصفوفة من النوع 0u‏ تحتوي على الأعمدة الثانوية في هذه 
العلاقة. 


© ف قيد المفتاح الرئيسي :ParentKeyConstraint‏ 


تعيد كائن قيد التفرد 17210116000152511:314؛ المفروض على المفتاح الرئيسي 
في هذه العلاقة. 


TA» 


7 ف قيد المفتاح الفرعي :ChildKeyConstraint‏ 
تعيد كائن قيد المفتاح الفرعي 1”0161201663:000151121214: المفروض على 
المفتاح الثانوي في هذه العلاقة. 


ال متداخلة :Nested‏ 
تفيد عند حفظ سجلات الجدول الرئيسي في ملف ]1> باستخدام الوسيلة 
32606 فلو جعلت قيمة هذه الخاصية ‘True‏ فسيتم حفظ السجلات 
الفرعية مع السجل الأصلي الذي تربطها به العلاقة الحالية. 

57 ف الخصائص الإضافية :Extended Properties‏ 


تعيد مجموعة الخصائص 206170011601105 التي تحتوي على 
الخضبائضن الإضافكة العبوة» وهي ممالة لتك الخاصتة بكائن الجدول, 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


۳۸۱ 


42 فئة مجموعة القيود ConstraintCollection Class‏ 


هذه الفئة ترث المجموعة ع1216112211021200116211021325» وکل عنصر من 
عناصرها من نوع فئة القيد و0135 0025118124 التي سنتعرف عليها لاحقا. 
وتفتلك هذه الف ة الخصبائصن و الؤسائل السهيرة المجبر عات عزرو ام آم 
ومعظمها يستخدم اسم القيد كمعامل» أو يستخدم كائن القيد 0536© الذي 
يمثله.. لهذا نحتاج هنا إلى التركيز على العناصر التالية فقط: 


57 لين العنصر رررء)1: 
أرسل إلى هذه الخاصية رقم القيد في المجموعة» أو نصا يحمل اسم القيدء 
لتعيد إليك كائن القيد 005214 الذي يمثله. 


#ا- إضافة 400: 
تضيف قيدا إلى المجموعة»؛ ولها الصيغ التالية: 

-١‏ الصيغة الأولى تستقبل كائن القيد 005114 المراد إضافته. 

؟- الصيغة الثانية تنشئ قيد تفرد 1[11011600115112114] وتضيفه إلى 
المجموعة.. وهي تستقبل ثلاثة معاملات: 

انم القيد, 

- كائن العمود 1232011 الذي يجب أن يكون متفردا. 

- قيمة منطقية إذا جعلتها 11 فسيتم جعل العمود المرسل إلى 
المعامل الثانى مفتاحا أساسيا للجدول. 

۳- الصيغة الثالثة مماثلة للصيغة السابقةء إلا أن معاملها الثاني يستقبل 
مصفوفة أعمدة Array‏ 211 وذلك إذا كان المفقاح 
المطلوب تفرده في الجدول يتكون من أكثر من عمود. 

ForeignKeyConstraint الصيغة الرابعة تنشئ قيد مفتاح فرعي‎ -٤ 
وتضيفه إلى المجموعة.. وهي تستقبل المعاملات التالية:‎ 

- اسم القيد. 1 
- كائن العمود :102800111 الأساسي. 
- كائن العمود :123300011 الفرعي. 

-٥‏ الصيغة الخامسة مماثلة للصيغة السابقةء إلا أن معامليها الثاني والثالث 
يستقبلان مصفوفة أعمدة 41183 012 123:20: وذلك إذا كان 
المفتاح الأساسي والمفتاح الفرعي يتكونان من أكثر من عمود. 

لاحظ أن جميع الصيغ ماعدا الأولىء» تعيد كائن القيد )00051211') الذي تم 
إنشاؤه وإضافته إلى المجموعة. 


YAY 


ويمكنك إضافة القيود إلى هذه المجموعة بطريقة مرئية في وقت التصميم 
وذلك من خلال نافذة خصائص الجدول.. لفعل هذا يجب أن يكون لديك كائن 
جدول في صينية مكونات النموذج (وهذا غير شائع)» أو يمكدك استخدام 
مجموعة بيانات عادية 1023125616 1120-1560 موضوعة في صينية 
المكونات» فعند عرص خصائصها في نافذة الخصائصء» سيمكنك ندا 
الخاصية و1261 لعرض محرر مجموعة الجداول» ولو حددت أي جدول في 
هذه المجموعةء فستظهر خصائصه في القسم الأيمن من النافذة» وستجد بينها 
الخاصية 20015121065.. ولو ضغطت زر الانتقال الموجود في خانة هذه 
الخاصية» فستظهر نافذة محرر مجموعة القيود» كما في الصورة: 

[Constraints Collection Editor Gk 


Constraint1 Properties: 
5 Data 


mH Columns DataColumn | 





051117 Constrain t1 
: / False 
E Tabk Tablel 


نم 
عه 
| »مه r‏ سم 
اضغط الزر 400 لإضافة قيد جديد.. ستظهر لك قائمة موضعية لتتيح لك 
اختيار نوع القيد» من بين النوعين التاليين: 


:Unique Constraint قيد التفرد‎ -١ 
عند ضغط هذا الاخثيارن ستظير لك ثاقةة إنشاء قد التفرد» وقد تعر فنا‎ 


YAY 


Unique Constraint 2× 


Name: 
[Constraint 


Columns: 


5 


[Primary key 


مك _ 1 





؟- قيد المفتاح الفرعي :Foreign Key Constraint‏ 
عند ضغط هذا الاختيار» ستظهر لك نافذة إنشاء قيد المفتاح الفرر عي» 


1 Foreign Key Constraint ا2‎ 


| Mame: 


1 
[Constraintı 


Specify the keys that relate tables in your dataset, 











Parent table: Child table: 
[rable1 -[ [rablez2 0 | 
Columns: 


Key Columns Foreign Key Columns 





Update rule: [Cascade ¥ | 
Delete rule: [Cascade wv | 
مز غدددمة‎ n: 3 


_ e | 





YA 


وبعد أن تضيف القيد سيظهر في القائمة اليسرى» وستظهر خصائصه في 
القائمة اليمنى. 


7# يمكن حذفه :CanRemove‏ 
تعيد 116 إذا كان من الممكن أن تحذف من المجموعة؛ كائن القيد 
51 المرسل إليها كمعامل» بدون حدوث خطأ في البرنامج.. مثلا: 
محاولة حذف قيد التفرد UniqueConstraint‏ قبل حذف قيد المفتاح الفرر عي 
FregnKeyConstraint‏ المرتبط به»ء تؤدي إلى حدوث خطأ في 
البرنامج» لهذا عليك استخدام هذه الوسيلة قبل استخدام الوسيلة Remove‏ أو 
.RemoveAt‏ 


:ColIlectionChanged المجموعة تغيرت‎ F 
ينطلق هذا الحدث عندما يتغير عدد عناصر مجموعة القيود» سواء بالحذف أو‎ 
الأضحافة: والتعاميل الثتياني غ لا الف فق الغ‎ 
الذي تعرفنا عليه من قبل في مجموعة‎ 1/5 

.DataTableCollection الجداول‎ 


Constraint Class فئة القيد‎ 42 





هذه الفئة أساسة مجردة 01255 8856 46512014 وتجب وراثتهاء وهي تعمل كفئة 
أم لكل من فئة قيد التفرد 1255© 17010116002512124 وقيد المفتاح الفرعي 
.ForeignKeyConstraint Class‏ 

وتمتلك هذه الفئة الخصضاتضن التالية: 


وخ اسم القيد :ConstraintName‏ 
تقرأ أو تغير اسم القيد. 
57 فز الجدول 12116: 
تعيد كائن الجدول 173421216 الذي ينطبق عليه القيد. 


57 ف الخصائص الإضافية :Extended Properties‏ 
تعيد مجموعة الخصائص 6117001160110م2:0 التي تحتوي على 
الخضنائصض الإضافئة له وهى سماثلة اثلك الخاضنة بكائن الحذول: 


2 فئة قيد التفرد UniqueConstraint Class‏ 


TAo 


هذه الفئة ترث الفئة 001511214)»؛ وهي تحتوي على تفاصيل قيد التفرد الذي 
يضمن عدم تكرار قيم حقل أو مجموعة من الحقول. 
ولحدث إنشاء هذه الفئة الصيغ التالية: 
-١‏ الأولى تستقبل كائن العمود 173420011:::0 الذي سيفرض عليه القيد. 
باك الضيعة الثانية فز يد هلي الضنيفة الا يمعامل متطقى + ١1]‏ جت فته 
م" يتم جعل العمود المرسل إلى المعامل الأول مفتاحا أساسيا للجدول. 
۳- الصيغة الثالثة تستقبل مصفوفة أعمدة 41183 1031320011130 تحتوي 
على الأعمدة التي سيفرض عليها القيد. 
-٤‏ الصيغة الرابعة تزيد على الصيغة السابقة بمعامل منطقيء إذا جعلته 116 
فسيتم جعل الأعمدة المرسلة إلى المعامل الأول مفتاحا أساسيا للجدول. 
5- هناك صيغ مماثلة للصيغ السابقة» لكنها تزيد بمعامل أول يستقبل اسم القيد. 
-٦‏ الصيغة الأخيرة تستقبل ثلاثة معاملات: 
د ١‏ اسح القيد. 00 
ت ا ت لتقل او ا ع 
- معامل منطقي إذا جعلت قيمته مںإ1 يتم جعل الأعمدة المرسلة إلى 
المعامل الثاني مفتاحا أساسيا للجدول. 
والكود التالي يعرف قيد التفرد على الحقل (11 لجدول المؤلفين: 
Dim ID As DataColumn = 1.115)‏ 
"Authors'"").Columns("'ID'")‏ 
Dim Uc As New UniqueConstraint('"ID Unique'"", ID, True)‏ 
إلى الآن لم يوضع هذا القيد في جدول المؤلفين» لذا عليك أن تضيفه كالتالي: 
Ds.Tables('"Authors'"").Constraints.Add(Uc)‏ 
لكن هذا القيدلن يعملء» إلا إذا جعلت للخاصيّة "فرض القيود" 
5 الخاصة بمجمو عة البیانات القيمة عمu٣آ:‏ 


Ds.EnforceConstraints = True 
وإضافة إلى ما ترثه من الفئة الأم» تمتلك فئة قيد التفرد الخاصيتين التاليتين:‎ 


52 زوز الأعمدة :Columns‏ 
تعيد مصفوفة تحتوي على الأعمدة التي يؤثر عليها هذا القيد. 


557 فل هل هو مفتاح أساسي 1122171263 15: 
تعيد 116 إذا كان هذا القيد مفروضا على المفتاح الأساسيّ للجدول. 


A 


4 فئة قد المفتاح الثانوي ForeignKeyConstraint Class‏ 


- الفئة 4 ترت الفئة N‏ وهي و على و قيد المفتاح 0 
الجدولين» ويمنع حذف أحد السجلات الأساسية في الجدول الرئيس” إذا كانت له 
سجلات فرعية في الجدول الثانوي» كما يمنع تعديل قيمة المفتاح الأساسي في أي 
سجل إذا كانت هذه القيمة مستخدمة في المفتاح الفر عي لسجلات الجدول الثانوي. 
ولحدث إنشاء هذه الفئة الصيغ التالية: 
-١‏ الصيغة الأولى تستقبل كائن العمود DataColumn‏ الذي يمثل المفتاح 
الرئيسي في العلاقة» وكائن العمود DataColunn‏ الذي يمثل المفتاح 
الفرعي في العلاقةء لفرض القيد عليهما. 
-"١‏ الصيغة الثانية ممائلة للصيغة السابقةء إلا أنها تتعامل مع مصفوفتين من 
النوع 3001111 : لمراعاة الحالة التي يتكون فيها المفقاح الأساسي 
والمفتاح الفرعي من أكثر من عمود. | 
2 اض اقا ريد علنى كل نيو القن اا كن مان ا ف 


اسم 


القيد. 


-٤‏ الصيغة الرابعة تستقبل المعاملات التالية بالترتيب: 


نصا يمثل اسم القيد 

نصا يمثل اسم الجدول الرئيسي 

نضا يمل طاق اننم الحدول. 

مصفوفة نصية تحتوي على أسماء الأعمدة التي تعمل كمفتاح أساسي. 
مصفوفة نصية تحتوي على أسماء الأعمدة التي تعمل كمفتاح فرعي. 
إحدى قيم المرقم عا R†ءء[عR۸†مءءءA‏ لوضعها في الخاصية 
cceptRejectRule‏ التي سنتعرف عليها بعد قليل. 

إحدى قيم المرقم 116 لوضعها في الخاصية 12»1»]6[11 التي 
سنتعرف عليها بعد قليل. 

إحدى قيم المرقم 1116 لوضعها في الخاصية عا Rم)ه‏ لمل التي 
سنتعرف عليها بعد قليل. 


5- الصيغة الخامسة مماثلة للصيغة السابقةء لكن ينقصها المعامل الثالث الذي 
يستقبل نطاق اسم الجدول. 
والمثال التالي يعرف قيدا من هذا النوع: 


FAY 


Dim ID As DataColumn = 5.115) 
"Authors").Columns("ID") 

Dim AuthorID As DataColumn = Ds. Tables( 
"Books'").Columns("' AuthorID") 

Dim Fkc As New ForeignKeyConstraint(" AuthorIDCnst"", 
ID, AuthorID) 

ويجب أن تضيف هذا القيد إلى الجدول الثانوي» مع ملاحظة أن خطأ سيحدث لو 

حاولت إضافته إلى الجدول الرئيسي.. والكود التالي يضيف القيد الذي أنشأناه إلى 

مجموعة قيود جدول الكتب: 

Ds.Tables(" Books'").Constraints.Add(Fkc) 

لاحظ أن تنفيذ هذه الجملة سيؤدي إلى إضافة قيد التفرد تلقائيا على العمود 17 في 

جدول المؤلفين» وذلك إذا لم يكن هذا القيد موجودا مسبقا. ٠‏ 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخصائص التالية: 


7 فع الجدول المرتبط ماطRelated1a:‏ 
تعيد كائن جدول 1034312116 يمثل الجدول الرئيسي في العلاقة. 


757 فز الأعمدة المرتبطة :RelatedColumns‏ 
تعيد مصفوفة أعمدة Array‏ 1021300[1132» تحتوي على الأعمدة التي 
تعمل كمفتاح أساسي في هذه العلاقة. 


:Columns الأعمدة‎ iF 
تحتوي على الأعمدة التي‎ 122011000 Array تعيد مصفو فة أعمدة‎ 
تعمل کمفتاح ثانوي في هذه العلاقة.‎ 


وع قاعدة القبول والرفض ءاRejec)Ru†صمAccep:‏ 
توضّح الفعل الذي سيتتمٌ اتخاذه عند استدعاء الوسيلة 
DataRow.AcceptChanges‏ أو الوسيلة ..DataRow.RejectChanges‏ 
وتاخذ هذه الخاصيّة إحدى قيمتي المرقم عا ec1۸‏ ]1م٥٥٥۸‏ التاليتين: 


TAA 


N0‏ | عند قيام أحد السجلات بقبول التغييرات أو رفضهاء لا يحدث 
أي شيء للسجلات المرتبطة به في العلاقة.. هذه هي القيمة 
الافتراضية. 

0 أ عند قيام أحد السجلات بقبول التغييرات أو رفضهاء يتم قبول 
التغييرات أو رفضها في السجلات المرتبطة به في العلاقة.. 
مثلا: لو تم قبول تغييرات سجل في جدول المؤلفين» يتم قبول 
التغييرات على التوالي لكل السجلات التي تحتوي على كتب 
هذا المؤلف في جدول الكتب. 








أ قاعدة الحذف 61661216 2: 
توضنح الفعل الذي سيتم اتخاذه مع السجلات الفرعية» عند حذف السجل 
الرئيسي الذي تنتمي إليه» وهي تأخذ إحدى قيم المرقم 10116 التالية: 


None‏ تترك السجلات الفرعية كما هي بدون تغييرء لكن هذا قد 
يؤدي إلى حدوث خطأ في البرنامج» لأن حذف أو تعديل 
السجل الرئيسي سيكسر قيد المفتاح الثانوي» ويترك بعض 
السجلات في الجدول الثانوي تشير إلى سجل غير موجود 
في الجدول الرئيسي. 

Cascade‏ يؤذي حذف أو تعديل السجل الرئيسى إلى حذف أو تعديل 
كل السجلات الثانوية المرتبطة به.. فدلا سيؤذي حذف 
أحد المؤلفين من جدول المؤلفين» إلى حذف كل كتبه من 
جدول الكتب. 

SetDefault‏ يؤذي حذف أو تعديل السجل الرئيسى إلى وضع القيم 
الافتراضيّة في حقول الف التانوى ام ا 
ااSeNu‏ إيؤذي حذف أو تعديل السجل الرئيسي إلى إفراغ حقول 
المفتاح الثانوي المرتبطة لتصير بها القيمة .DbNull‏ 











وغ قاعدة التحديث :Update Rule‏ 
توضح الفعل الذي يتم اتخاذه مع السجلات الفرعية» عند تغيير قيم السجل 
الرئيسي الذي تنتمي إليه» وهي تأخذ إحدى قيم المرقم 10016 التي تعرفنا 
عليها الخاصية السابقة. 
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لهماؤ ‏ 
عروض البيانات 


Data Views 


تتيح لك العروض 77167 عرض بعض أو كل سجلات الجدول بالترتيب الذي 
تريده» دون التأثير على سجلات الجدول الأصلي.. هذا يمنحك مرونة عالية عند 
عرض البيانات للمستخدم» دون الحاجة إلى إعادة إرسال استعلامات مختلفة إلى 
قاعدة البيانات. 


وفكرة العرض بسيطةء فكائن العرض يحتوي على فهرس 10062 يشير إلى 
سجلات الجدول» ولا يحتوي على السجلات نفسها.. هذا يجعل كائن العرض سريعا 
في أداء عمليات الترشيح عمزمرع)111 والترتيب عم:ه5 والبحث «Searching‏ 
دون أن يستهلك مساحة كبيرة في الذاكرة! 

لاحظ أن فهرس السجلات يتم إنشاؤه عند إنشاء كائن العرضء ويعاد إنشاؤه مرة 
أخرى إذا تم تغيير طريقة الترتيب أو الترشيح.. لذا من الأفضل أن تحدد مواصفات 
الترتيب والترشيح عند إنشاء كائن العرض لتوفر على نفسك الوقت الضائع في 
إعادة إنشاء الفهرس. 


۹۰ 


© واجهة قائمة الربط 
IBindingList Interface‏ 


هذه الواجهة ترث واجهة القائمة )15 1[1[» وهي تقدم الوسائل اللازمة للتعامل مع 
مصدر البيانات Source‏ 8 من خلال أدوات ربط البيانات 
.Data-Bound Controls‏ 


وتمتلك هذه الواجهة الخصائص التالية: 


57 ف السماح بالتحرير :AlIl ow Edit‏ 
تعيد 116 إذا كان من الممكن تغيير قيمة أي عنصر في القائمة. 


57 ف السماح بالجديد :AIl ow New‏ 
تعيد مں ۲آ إذا كان من الممكن إضافة عنصر جديد إلى القائمة باستخدام 
الوسيلة .Add New‏ 


57 ف السماح بالحذف :AllowRemove‏ 
تعيد 106 إذا كان من الممكن حذف عنصر من القائمة باستخدام الوسيلتين 
Remove‏ و .RemoveAt‏ 


7 ف تد عم الترتيب :SupportsSorting‏ 
تعيد ں٣۲‏ إذا كانت القائمة تسمح بترتيب عناصرها.. وإذا كانت قيمة هذه 
الخاصية ع1*015» فستؤدي محاولة استخدام أي من خصائص الترتيب إلى 
حدوث خطأ من gill‏ ع .NotSupportedException‏ 


:SupportsSearching تدعم البحث‎ iF 
تعيد 1516 إذا كانت القائمة تتيح البحث في عناصرهاء وتتيح ترتيبها.‎ 


فط هل هي مرتبة 0ع195016: 
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7 هزر اتجاه الترتيب :SortDirection‏ 


توضح اتجاه ترتيب القائمة» وهي تعيد إحدى قيمتي المرقم 
160 التاليتين: 


Ascending‏ | ترتيب تصاعدي. 
Descending‏ | ترتيب تنازلي. 











57 فر خاصية الترتيب 7د م501510: 


تعيد كائنا من نوع فئة واصف الخاصية «PropertyDescriptor Class‏ 
وهو يحتوي المعلومات اللازمة لمعرفة الخاصية المستخدمة في ترتيب 
عناصر القائمة» وذلك إذا كانت القائمة تحتوي على كائنات و]اءء 01 تمتلك 
خصائص مختلفة.. مثلا عند التعامل مع كلئن عرض فيه سجلات أحد 
الجداول» يمكنك أن تحدد أحد القول لترتيب السجلات تبعا له. 


37 ف تدعم التنبيه عن التغيير :SupportsChangeNotification‏ 


تعيد ع1 إذا كانت القائمة تطلق الحدث 115601232860 عند حدوث تغير 


كبا فاك هذه الواحية الزسائل الا 


إضافة فهرس 400172062: 

أرسل إلى هذه الخاصية كائنا من النوع ›PropertyDescriptor‏ لتقوم 
بإضافة الخاصية التي يشير إليهاء إلى مجموعة الفهارس المستخدمة في 
البحث في عناصر القائمة. 1 


حذف فهرس :RemoveIndex‏ 

أرسل إلى هذه الخاصية كائنا من النوع ›PropertyDescriptor‏ لتقوم 
بحذف الخاصية التي يشير إليهاء من مجموعة الفهارس المستخدمة في البحث 
في عناصر القائمة,. 1 
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#> إضافة عنصر جديد 400716: 
لا تستقبل هذه الوسيلة أية معاملات» ولكنها تنشئ عنصرا جديدا من نفس نوع 
عناصر القائمة» وتضيفه إليهاء وتعيد إليك كائنا 06/01 يحمل مرجعا إلى 
هذا العحصر المصياف: 


2# تنفيذ الترتيب :1756م 4: 
تقوم بترتيب عناصر القائمة» وهي تستقبل معاملين: 
- كائن من النوع إpertyDescrip†0دPr»‏ يوضح الخاصية التي سيتم 
ترتيب العناصر على أساسها. 
- إحدى قيمتي المرقم 110ع1.15]50111(016 توضح اتجاه الترتيب. 


7 حذف الترتيب 12611105501:6: 
تعيد عناصر القائمة إلى ترتيبها الأ حلي الذي ا ى 
.ApplySort‏ 


2# بحث Find‏ : 
- كائن من النوع إ0اماsمpertyDدPr»‏ يوضح الخاصية التي سيتم 
البحث عن قيمتها. 
- كائن ٥زط0‏ يحمل القيمة المراد البحث عنها. 


كما تمتلك هذه الواجهة الحدث التالي: 
القائمة تغيرت age‏ 1.15)0: 


ينطلق عند حدوث تغير في عناصر القائمة.. والمعامل الثاني e‏ لهذا الحدث 
من النوع sع۲ hanged 8٤ ve٤4‏ istاء‏ وهو يمتلك الخصائص التالية: 
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E 


7 
E 


E 





ListChangedType 


NewIndex 
OldIndex 


PropertyDescriptor 


List hanged ype‏ التي توضح نوع 

التغيير الذي حدث» وهذه القيم هي: 

- 1165©1: حدث تغير في عدد كبير من 
العناضيو. 

- 6060ماع ]1: إضافة عنصر. 

:]temDeleted -‏ حذف عنصر. 

- 11610110560: تغير موضع عنصر. 

- 1160131860 : تغيرت قيمة 

:PropertyDescriptorAdded -‏ 
إضنافة و أف خاصية. 

:PropertyDescriptorDeleted -‏ 
کف واصيفه خاصية 

:PropertyDescriptorChanged -‏ 
تغيير واصف خاصية. 

تعيد رقم العنصر الذي تغير في القائمة. 

تعيد رقم العنصر قبل تغيير موضعه في 

القائمة. 

:11001 1م10 يحتوي على 

واضف الخاصية: وذلك إذا كان التغيير 

قد حدث لواصف إحدى الخصائص. 





۹٤ 




















>5 واجهة القائمة محددة النوع 
ITypedList Interface‏ 


تحصل هذه الواجهة على خصائص العنصر الذي سيتم الارتباط Binding‏ بد 
وهي تمتلك الوسيلتين التاليتين: 


1# معرفة اسم القائمة :GetListName‏ 
تعيد اسم القائمة التي سيتم الارتباط بها. 


7# معرفة خصائص العنصر وع1)زء 1166111210 ©: 
أرسل إلى هذه الخاصية مصفوفة من gill‏ ع PropertyDescriptor‏ بها 
اكات التي سي الارتباط ها كي القائية دإ ك مجر عة من النوع 
110 ببها خصائص هذه الكائنات.. لاحظ 
ف واف لخا فف شا 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


40° 


42 فة مدير العرض 
DataViewManager Class‏ 


هذه الفئة تمثل الواجهتين از اعہ¡ل18¡n‏ و [ype ist‏ كما أنها ترث الفئة 
Marsha] ByValueComponent‏ مما يتيح لك إضافتها إلى صينية مكونات 
النموذج» وإن كان عليك أن تضيفها أولا إلى صندوق الأدوات. 
وتتيح لك هذه الفئة لك التحكم في كيفية عرض سجلات كل جداول في مجموعة 
البيانات. 
ويمكن الحصول على مدير العرض من مجموعة البيانات» باستخدام الخاصيّة 
1ه كالتالي: 
Dim DVM = Ds.DefaultViewManager‏ 
ولحدث إنشاء هذه الفئة صيعتان: 
-١‏ الأولى بدون معاملات. 
۲- والثانية تستقبل مجموعة البيانات التي يتعامل معها مدير العرض.. مثال: 
Dim DVM As New DataViewManager (Ds)‏ 


ود تاك مدير العرض الخاصيتين التاليتين: 


ونج مجموعة البيانات 1ع1(2]25: 
تقرأ أو تغيّر مجموعة البيانات التي يتعامل معها مدير العرض. 


7 ف إعدادات عرض البيانات :DataViewSettings‏ 
تعيد مجموعة إعدادات العرض ›DataViewSettingCollection‏ وهي 
مجموعة تمثل الواجهة 10011601100» وتحتوي على إعدادات العرض 
الخاصة بجداول مجموعة البيانات» وكل عنصر من عناصرها من نوع الفئة 
5 اسلتي سنتعرف عليها لاحقا. 


51 


لاحظ أن هذه المجموعة للقراءة فقط لهذا لا يمكنك إضافة أية عناصر إليها.. 
لكن كل جدول يضاف إلى مجموعة البيانات» يضيف عنصر إعدادات 
العرض الخاص به إلى هذه المجموعة تلقائيا. 
ويمكنك الحصول على كائن إعدادات الجدول من هذه المجموعة» إما باستخدام 
رقم الجدول أو اسمه أو كائن الجدول 1734818616 الذي يشير إليه.. مثال: 
Dim Vs As DataViewSetting =‏ 
Ds.DefaultViewManager.DataViewSettings(0)‏ 


ويمتلك مدير العرض الوسيلة التالية: 


#< إنشاء عرض بيانات :CreateData View‏ 

أرسل إلى هذه الوسيلة كائن الجدول »10313123616 لتنشئ عرضا wع۷1‏ 
لسجلاته؛ تبعا للإعدادات الخاصة بهذا الجدول في مجموعة الإعدادات 
95 مورووتعيد هذه الوسيلة كائن العرض 103131167 الذي 

تم إنشاؤه.. مثال: 
Dim TblIAuthors As DataTable = Ds.Tables('"Authors"")‏ 
Dim DV As DataView = Ds.DefaultViewManager.‏ 

CreateDataView(TbIAuthors) 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النار» وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


۹۷ 


Data ViewSetting Class فئة إعدادات العرض‎ 2 


تحتوي هذه الفئة على إعدادات العرض الافتراضيّة التي يتمّ استخدامها مع الجداول 
المعروضة. 
وليس لهذه الفئة حدث إنشاءء ولكن يمكنك الحصول على نسخة منها خاصة بأحد 
الجداول من خلال مجموعة إعدادات العرض 112855 103421716756 كالتالي: 
Dim Vs As DataViewSetting =‏ 
Ds.DefaultViewManager.DataViewSettings("" Authors'")‏ 


:Table BF 
تعيد كائن الجدول 1021212116 الذي ينتمي إليه كائن الإعدادات الحالي.‎ 


7 يز مدير العرض :DataView Manager‏ 
تعيد كائن مدير العرض 861 1(31317167:1/1212 الذي يحتوي كائن 
الإعدادات الحالي. 


وخ مرشح حالة الصفوف :RowState Filer‏ 


تحدد حالة الصفوف التي تريد عرضهاء وهي تأخذ إحدى قيم المرقم 
71-51 اسلتالية: 


None‏ أي حالة. 
Unchanged‏ عرض الصفوف التي لم تتغير. 
Added‏ عرض الصفوف المضافة. 
Deleted‏ عرض الصفوف المحذوفة. 


.Original Version النسخة الأصلية للصفوف‎ __ Origina]R ows 
.Current Version االنسخة الحالية للصفوف‎ 00275 
النسخة الأصلية للسجلات التي تم تعديلها.‎ | Modified Origin 
النسخة الحالية للسجلات التي تم تعديلها.‎ || + 1 











]ا مرشح الصفوف :R‌0W ۴ ¡[٤٥‏ 
تقرأ أو تغير الشرط الذي يتم على أساسه اختيار السجلات التي يعرضها كائن 
العرض.: ويتم تكوين الشرط في هذه الخاصية؛ ينفس'الطريقة المستخدمة في 
تكوين شرط الخاصية .DataRow. Expression‏ 
والمرشح التالي يعرض الكتب التي يقل ثمنها عن © جنيهات: 


Vs.RowFilter = "Price > 5" 


۹۸ 





























وخ الترتيب :501: 
تحدد النص المستخدم في ترتيب السجلات المعروضة؛ وهو يتكون من اسم 
الحقل المستخدم في الترتيب» متبوعا باتجاه الترتيب.. مثلا: لترتيب صفوف 
جدول الكتب تنازليا على حسيب اسم الكتاب» استخدم القيمة التالية لهذه 
Vs.Sort = "Book DESC"‏ 


وخا تطبيق الترتيب الافتراضي :121116501 ,امم :A‏ 
إذا جعلت قيمة هذه الخاصية ع111» فسيتم تطبيق الترتيب الافتراضي 
للصفوف (كما في الجدول الأصلي).. والقيمة الافتراضية لهذه الخاصية هي 
‘False‏ وفي هذه الحالة يتم تطبيق التر تيب الموضح في الخاصية )ر50. 


العرض.. في هذا المشروع نتيح للمستخدم عرض جداول قاعدة الكتب» باختيار 
الجدول الذي يريده من القائمة المنسدلة "عرض الجدول"» كما نتيح له اختيار 
مرشح الصفوف وطريقة الترتيب كما هو موضح في الصورة: 







HE Form1 


| AuthorID < | PublisherID | ClassID | Publish_Date 
6 | |1970 

6 1101 
7 0 

| 1/20 








عرض الجدول شرط على الحقل 
[Books -1‏ و [- [Book - | [like‏ 


ترتيب بواسطة الحقل 


۳۹۹ 

















دعنا نفهم كيف يعمل هذا المشروع: 


في حدث تحميل النموذج 1,030» نستخدم موصلات الجداول لملء 
مجموعة البيانات» ثم نضيف الجداول إلى القائمة المركبة 5ع51121آ. 
في حدث تغير العنصر المحدد في قائمة الجداول 
6:20 نعرض سجلات الجدول الذي اختاره 
المستخدم في جدول العرضء ونفرغ قائمة الحقول 1.,50116105 وقائمة 
الترتيب 1,5695016 من محتوياتهماء ونضيف إلى كل منهما أسماء أعمدة 
الجدول الحالي.. ونظرا لأن المستخدم قد يريد عرض كل السجلات بدون 
ترتيب» فسنضيف إلى كل مجموعة عنصرا إضافيا اسمه (عم210) 
وسنجعله أول عنصر في كل منهما. 
وللتحكم في طريقة عرض الجدول» سنستخدم إعدادات العرض الخاصة 
به.. ولتسهيل الكود في باقي البرنامج» سنضع كائن إعدادات الجدول 
الحالي في متغير معرف على مستوى النموذج اسمه :ViewSettings‏ 
Dim T As DataTable = LstTables.SelectedItem‏ 
ViewSettings = Ds.DefaultViewManager.‏ 
DataViewSettings(T)‏ 
في حدث تغير العنصر المحدد ×علمآلع)ءع1مS‏ في قائمة الحقول 
5,:, سنعطل قائمة معاملات المقارنة 1,50 ومربع نص القيمة 
مuاa ٠1×۷‏ وذلك إذا اختار المستخدم العنصر (None)‏ وهو العنصر 
رقم صفر في القائمةء أما إذا اختار المستخدم أحد أعمدة الجدول» فسنفعّل 
قائمة المعاملات وجدول القيمة حتى يمكن استخدامهما في تكوين مرشح 
البحلات: کل بهذ امك فعلهبالسطرين اكان فخت 
LstOp.Enabled = (LstField.SelectedIndex <> 0)‏ 
TxtValue.Enabled = LstOp.Enabled‏ 
في حدث تغير العنصر المحدد 5616016012062 في قائمة حقل الترتيب 
+5011 إذا اختار المستخدم العنصر (7026) وهو العنصر رقم صفر 
في القائمة» فسنعطل قائمة اتجاه الترتيب 1,56501101061 ونجعل للخاصية 
1115011 الخاصة بإعدادات العرض القيمة 111" لعرض 
السجلات بترتيبها الأصلي.. أما إذا اختار المستخدم أحد أعمدة الجدول؛ 
فسنفعل قائمة اتجه الترتيب ونضع ج1315 في الخاصية 
15011 لانلنعرض السجلات بالترتيب الذي يريده المستخدم.. 
كل هذا يمكن قله دالبل يخ تالفح فكيب: 


LstSortOrder.Enabled = (LstSort.SelectedIndex <> 0)‏ 
ViewSettings.ApplyDefaultSort = Not LstSortOrder.Enabled‏ 
3 أخيراء في حدث ضغط الزر تنفيذء سنقوم بتنفيذ خيارات العرض التي 
اختارها المستخدم» حيث سنكون مرشح السجلات كالتالي: 
If LstField.SelectedIndex = 0 Then‏ 
ViewSettings.RowFilter = ""‏ 
Else‏ 
ViewSettings.RowFilter = LstField.Text & " " &‏ 
LstOp.Text & " " & TxtValue. Text. Trim‏ 
End If‏ 
لاحظ أن المستخدم هو المسئول عن كتابة القيمة المناسبة بالشكل الصحيح 
في مربع النص. . فعليه مثلا أن يكتب رقما في مربع النص إذا كان الحقل 
الذي اختاره رقمياء وأن يكتب نصا ويضعه بين علامتي التنصيص '' إذا 
كان الحقل يتعامل مع نصوص أو تواريخ.. وإذا اختار المعامل 1N‏ فعليه 
أن يفصل بين القيم بالعلامة , ويضع كل ما كتبه بين قوسين ( ).. وهكذا. 
لاحظ أيضا أن وضع شرط خاطئ في الخاصية 12011711617 لا يسبب 
خطأ في البرنامج» لكنه يجعل مدير الإعدادات يتجاهل هذه الإعدادات ولا 
ينفذها. 
بعد هذا سنكون قيمة الخاصية 5014 بالكود التالي: 
If LstSort.SelectedIndex = 0 Then‏ 
ViewSettings.Sort = ""‏ 
Else‏ 
ViewSettings.Sort = LstSort. Text & " " &‏ 
If(LstSortOrder.SelectedIndex = 0, "ASC", "DESC")‏ 
End If‏ 
أخيراء سننشئ كائن عرض ونعرضه في جدول العرض.. لفعل هذا 
سنحصل على مدير العروض من كائن إعدادات العرضء ونستخدم الوسيلة 
7177 الخاصة به كالتالي: 
Dim Dv = ViewSettings.DataViewManager.‏ 
CreateDataView(ViewSettings. Table)‏ 
Dgv.DataSource = Dv‏ 
وهكذاء وبهذا البرنامج البسيط الذي لم نكتب به الكثير من الكود» صار باستطاعة 
المستخدم عرض جميع بيانات قاعدة الكتب» وبأي طريقة عرض يحبها! 


-ة واجهة ربط قائمة العرض 
IBindingListView Interface‏ 


هذه الواجهة ترث الواجهة ائ اعمالم181ء وهي تقدم إمكانيات متقدمة في ترشيح 
السجلات Filtering‏ وترتيبها .Sorting‏ 


وتمتلك هذه الواجهة الخصائص التالية: 


وخ المرشح r‏ م)]F۴İ:‏ 
تحدد الشرط الذي يتم على أساسه اختيار السجلات لعرضها.. مثل: 
"Price > 5"‏ 


57 ف واصفات الترتيب :SortDescriptions‏ 
تعيد مجموعة للقراءة فقط من gill‏ ع «ListSortDescriptionCollection‏ 
وهي تمثل واجهة القائمة 11.156» وكل عنصر من عناصرها من نوع الفئة 
200 > > التي سنتعرف عليها لاحقا. 


57 ف تدعم الترتيب المتقدم :SupportsAdvancedSorting‏ 
تعيد 116 إذا كان مصدر البيانات يستطع ترتيب السجلات تبعا لقيم أكثر من 
عمود. 


7 ف تدعم الترشيح :Supports Filtering‏ 


رفك هذه الو احهة الوبيلة الثالية: 
ب إزالة المرشح :RemoveFilter‏ 


تلغي عملية الترشيح» وتعيد عرض جميع السجلات بدون مراعاة شرط 


م فة و اصف قرب _القائمة 
ListSortDescription Class‏ 


تى هذه اة عى المطر مات اذز مة ريي عتاسر قائمة البياتاك: 
رسف ت إنشاء هذه الفكة معاملين: 
- واصف الخاصية 01]م 500061171065011 التي سيتم الترتيب على 
أساسها. 
- إحدى قيمتي المرقم 115501110116110 التي توضح اتجاه 


وتمتلك هذه الفئة الخاصيتين التاليتين: 


وخ واصف الخاصية :PropertyDescriptor‏ 
تقرأ أو تغير واصف الخاصية 206171065011101 التي سيتم الترتيب 
على أساسها. 


3 اتجاه الترتيب :SortDirection‏ 
توضح اتجاه الترتيب» وهي تأخذ إحدى قيمتي المرقم ListSortDirection‏ 
وقد تعرفنا عليهما سابقا. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


42 فئة عرض البيانات Class‏ 10242571631 


هذ الففة تمتل الواجهات IBindingList View‏ و IBindingList‏ 
و cT yped List‏ كما أنها ترث الفئة «MarshalByValueComponent‏ مما 
يتيح لك إضافتها إلى صينية مكونات النموذج» وإن كان عليك أن تضيفها أولا إلى 
صندوق الادوات. 
ويمكنك استخدام كائن عرض البيانات للحصول على طريقة عرض مختلفة 
لسجلات الجدول» سواء بترتيبها أو باختيار جزء من السجلات تبعا لشرط معين.. 
كما يمكنك ربط هذا الكائن بأدوات عرض البيانات كما سنرى فى الفصل التالى» 
وبهذا تتحكم في طريقة عرض البيانات في برنامجك. ۰ ٠‏ 
ويمكنك الحصول على كائن العرض الافتراضي للجدول باستخدام الخاصية 
1171677 كالتالي: 
Dim Dv As DataView = TblAuthors.DefaultView‏ 
ومن ثم يمكنك تغيير خصائصه لتغيير طريقة عرضه. 
ولحدث إنشاء هذه الفئة الصيغ التالية: 
-١‏ الصيغة الأولى بدون معاملات. 
-١‏ الصيغة الثانية تستقبل كائن الجدول 1222123616 الذي سيتعامل معه كائن 
العرض. 
"- الصيغة الثالثة تزيد على الصيغة السابقة بثلاثة معاملات» هي بالترتيب: 
- نص يحتوي على شرط ترشيح السجلات :زعغ1101:111. 
- نص يحتوي على شرط ترتيب السجلات 50116. 
- إحدى قيم المرقم عاج ›Data View R0 wS‏ توضح حالة السجلات 
التي يتم عرضها. 
والمثال التالي ينشئ كائن عرض» يعرض كتب توفيق الحكيم مرتبة تصاعديا على 
حسب اسمائها: 
Dim Dv As New DataView(Ds.Books,‏ 
,""'تgذıق‏ الحكيم' = "Parent(FK_Books_Authors).Author‏ 
"Book", DataViewRowState.CurrentRows)‏ 
ويمكنك تجربة هذا المثال بضغط الزر "كتب توفيق الحكيم" في المشروع sسwعا۷.‏ 
وبالإضافة إلى ما تمثله من خصائص الواجهات IBindingList View‏ 
و BindingList‏ و 601156م:115» تمتلك فئة العرض بعض الخصائص الممائلة 
في اسمها ووظيفتها لخصائص كائن إعدادات العرض 1032181/161:561615» مثل: 


57 لز الجدول 1:21 
57 فيز مدير العرض DataView Manager‏ 


٤ 


و مرشح الصفوف RowFil(er‏ 

و مرشح حالة الصفوف RowStateFilter‏ 

“ل الترتيب 60۲ 

تطبیق الترتيب الافتراضي 6-د2111)50]» (019:1م 4 


والكود التالي يجعل كائن العرض يحتوي على أسماء الكتب التي تبدأ أسماؤها 

بالحروف من الألف إلى التاء فقط» ويرتبها تنازليًا عن طريق اسم الكتاب ورقم 
المؤلف: 

Dim T As DataTable = Ds.Tables("'Books'"") 

Dim Dv As DataView = T.DefaultView 

Dv.RowFilter = " Book < 'ث'‎ " 

Dv.Sort = "Book, AuthorID DESC" 


كافك فة الع رض الخاضية الثالية. 


7 ف العنصر ص ع)!: 
هذه هي الخاصية الافتراضية» وهي تعيد كائن عرض الصف 
771657 الموجود في كائن العرض الحالي في الموضع المرسل 
كمعامل.. مثال: 

Dim R As DataRowView = Dv(0) 
لاحظ أن كائن العرض يعمل كقائمةء لهذا تستطيع المرور عبر كل صفوف‎ 

كائن العرض باستخدام حلقة التكرار ط٥۵٤‏ 101 كالتالي: 
For Each R As DataRowView In Dv‏ 

MsgBox(R('Book")) 

Next 


وتمتلك فئة العرض الوسائل التالية: 


ا إضافة سجل جديد 400716: 
تضيف سجلا جديدا إلى كائن العرضء تحتوي خاناته على القيم الافتراضية 
في الأعمدة التي لها قيم افتراضية؛ وعلى العدم 176711011 في الأعمدة التي 
تسمح بهذا.. لاحظ أنّ هذا السجلّ سيضاف أيضا إلى الجدول الأصليّ أيضا 
قاعدة البيانات.. هذا يجعلك مطمئنا إلى أن السجلات الجديدة التي يضيفها 


ف 


المستخدم إلى جدول عرض :103120311017167 مرتبط بكائن عرضء» ستتم 
إكبافتها تلثاكنا إلى مح عة الات وسشعامل معا السبحلاك العافية. 
وتعيد هذه الوسيلة كائن عرض الصف 103481203917167 الذي يشير إلى 
الصف الحديد الذى شك إضافته» هما كح لك فير قم خافاقة: 


حذف ع]1(16: 
تحذف السجل الذي ترسل إليها رقمه كمعامل.. هذا السجل سيتم حذفه في 
الحال من كائن العرضء وستكون أمامنا حالتان بالنسبة للجدول الأصلي: 
-١‏ إذا كان السجل مضافا إلى الجدول (40060 = 12075126)»: فسيتم 
فة تاا مق الجدو لو لن يمكدك استفاذكةه باستد غاء الوسيلة 
.DataTable.RejectChanges‏ 
-١‏ إذا كان السجل أحد سجلات الجدول الأساسيةء فسيظل في الجدول 
الأصلي مع جعل حالته محذوفا (0م)]ع1عء72 = ..)NRowState‏ ولو 
استدعيت الوسيلة وعع موط0)]ءء(1021812616.186 فستعيد السجل إلى 
كائن العرض 10342317167 مع تحويل حالته في الجدول الأصلي إلى 
.Unchanged‏ 
لاحظ أن ترتيب السجلات في كائن العرض قد يختلف عن ترتيبها المجموعة 
35 في الجدول الأصليء سواء بسبب إعادة ترتيبهاء أو بسبب أخذ جزء 
فقط من سجلات الجدول الأصلي تحقق شرطا معينا.. لهذا عليك أن تستخدم 
الوسيلة 110 لتبحث في كائن العرض عن السجل الذي تريد حذفه لتحصل 
على رقمه.. والمثال التالي يفترض أن 7 هو كائن عرض يعرض بعض 
سجلات جدول الكتب» ويستخدمه لحذف أحد الكتب: 
Dv.Sort = "Book"‏ 
("الطعام لكل أم'(Dv.Find‏ = Dim I‏ 
If I >< -1 Then Dv.Delete(T)‏ 


#ا- بحث Find‏ : 
أرسل إلى هذه الوسيلة كائنا 04 ع[06» لتبحث عن القيمة التي يحملها في 
العمود المستخدم لترتيب السجلات (كما تحدده الخاصية 901).. وتعيد هذه 
الوسيلة رقم أول سجلّ يحتوي على القيمة المطلوبةء وإذا لم تعثر على أي 
سجل» تعيد .١-‏ 
وتوجد صيغة ثانية لهذه الوسيلةء تستقبل مصفوفة كائنات» وذلك إذا كان كائن 
وقد استخدمنا هذه الوسيلة في المشروع 0000000 . في هذا 
المشروع يستطيع المستخدم إدخال أسماء الطلاب في النافذة الرئيسية» وضغط 
الرابط الموجود في عمود الدرجات لعرض نافذة فيها درجات الطالب في 
المواد المختلفة.. لفعل هذاء اتبعنا الخطوات التالية: 
- حصلنا على كائن العرض الافتراضي الخاص بجدول الطلبة» باستخدام 
الخاصية 1055101016115.511061215.106181119/161: ومررنا إليه 
رقم صف التلميذ الحالي (ممثلا بالمتغير :10)؛ لنحصل على كائن 
عرض هذا الصف .DataRow View‏ 
Dim StdRel = DsStudents.Students.ChildRelations(‏ 
0).RelationName‏ 
Dim RowView = DsStudents.Students.‏ 
DefaultView(dx)‏ 
- أرسلنا إلى الوسيلة 063011057155 الخاصة بكائن الصف» اسم 
العلاقة التي تربط جدول التلاميذ بجدول الدرجات» لنحصل على كائن 
عرض يحتوي على درجات التلميذ الحالى» لنستخدمه كمصدر بيانات 


لرل العرص الى يعررطي الدرجاك . هذا يحل جميع الصفوف 
التي تضاف إلى هذا الجدول» تضع تلقائيا رقم هذا التلمية في العمود 
:StudentID‏ 


Dim Grades = RowView.CreateChild View(StdRel) 
لوكانت هذه أول مرة نعرض فيها درجات هذا التلميذء فسيظهر‎ - 
الجدول فارغا.. هذا غير مقبولء لأن علينا أن نعرض للمستخدم أسماء‎ 
الموادء ليكتب هو درجات الطالب المناظرة لها مباشرة. . ونظرا لأننا‎ 
نسمح للمستخدم بتحرير جدول المواد الدراسية بضغط الزر ' "عرض‎ 
المواد"» فمن الممكن أن تضاف مواد جديدة لم نقم بإضافتها إلى نافذة‎ 
الدرجات من قبل.. لهذا علينا أن نستخدم الوسيلة 13100 للتأكد من أن‎ 
رقم المادة غير موجود» ومن ثم نضيفها.. السبب في هذا أن تكرار‎ 
نفس المادة مع نفس الطالب سيؤدي إلى حدوث خطأ بسبب قيد التفرد‎ 
المفروض على هذين الحقلين.. لكن استخدام الوسيلة 1300 يوجب‎ 


۷ 


علينا أولا أن نستخدم الحقل (9116[60111 كمفتاح للترتيب في الخاصية 
:Sort‏ 
Grades.Sort = "SubjectID"‏ 
بعد هذا سنمر على كل مادة في جدول المواد» ونبحث عن رقمها في 
جدول الدرجات» ولو لم تكن موجودة (نتيجة البحث = »)١-‏ علينا 
استخدام الوسيلة 4007177 لإضافة صف جديد إلى كائن العرض.. 
هذا الصف يكون فارغاء ما عدا الحقل (56106411 الذي يأخذ تلقائيا 
رقم التلميذ الذي نتعامل معه.. لهذا علينا نضيف رقم المادة إلى هذا 
الصف الجديد.. لاحظ أن اسم المادة سيضاف تلقائيا لأنه عمود 
محسوب مبني على قيمة الحقل (561061411.. لكن هذا لن يحدث 
طالما ظل هذا الصف الجديد هو الصف الحالي. . لحسن الحظ أن 
الصف الحالي يتغير تلقائيا إذا أضفنا صفا جديدا بعده» لكن المشكلة 
تظل في آخر صف نضيفه.. لهذا علينا استخدام الوسيلة 10010 
لإنهاء تحرير الصف الحالي.. هذا سيجبر العمود Subject‏ على 
حساب قيمته» و عرص اسم المادة تلقائيا* 
Dim SubjRows = DsStudents.Subjects.Rows‏ 
For i = 0 To SubjRows.Count - 1‏ 
Dim SbjID = SubjRows(i)('"ID")‏ 
If Grades.Find(SbjID) = -1 Then‏ 
Dim Rv = Grades.AddNew(0‏ 
Rv("SubjectID") = SbjID‏ 
Rv.EndEditO‏ 
End If‏ 
Next‏ 
ومن الأذكى أن تخفي رقم التلميذ ورقم المادة عن المستخدم» لأنه 
سيتعامل فقط مع المادة ودرجة الطالب فيها.. وستجد هذا الكود كاملا 
في الإجراء وملهإ6س0ط؟ الذي يتم استدعاؤه من الحدث 
122001116 في النموذج ٤8Studenص۴۲»‏ ومن الحدث 
Selected Index‏ في النموذج .Frn¬Grades‏ 


2# بحث عن الصفوف 0W‏ ۸ 4ہ۴: 
ماق للوسيلة اليايقة فى ها ولقنها تة مصقوفة من التوع 
ow View‏ تحتوي على كل السجلات التي تحتوي على القيمة 
المطلوبة. 


7# التحويل إلى جدول 101816: 
تنشئ جدولا جديدا وتنسخ اليه السجلات الموجودة في كائن العرض الحالي» 
وتعيد إليك كائن جدول 1036812116 يشير إليه.. ولهذه الوسيلة الصيغ التالية: 
23 الصحعة الأول عدون سحام 
7-. الصيغة الثانية تستقبل نضا لتستخدمه كاسم للجدول. 
#ن الضبيكة القالثة قو ل معا 
- قيمة منطقية إذا جعلتها 116 فسيتم استبعاد الصفوف المكررة 
التي تتشابه قيم أي من خاناتها مع أي صفوف أخرى. 
- مصفوفة نصية تحتوي على أسماء الأعمدة التي تريد نسخها إلى 
الجدول.. وستظهر الأعمدة في الجدول بنفس ترتيبها في 
المصفوفة.. لاحظ أن هذه هي الطريقة الوحيدة التي تستطيع بها 
الحصول على جدول يختلف في عدد أعمدته وترتيبها عن الجدول 
الأصلي. 
4- الصيغة الرابعة تحتوي على معاملات الصيغتين السابقتين معا. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


-د واجهة الكائن القايل للد 
IEditableObject Interface‏ 


(مثل كائن عرض صف البيانات «(DataRow View‏ مع القدرة على إلغاء 
التغييرات أو قبولها. 
وتمتلك هذه الواجهة الوسائل التالية: 


:Begin Edit بدء التحرير‎ 7# 


> إلغاء التحرير 22262115034 ©: 
تلغي عملية التحرير وتعيد إلى الكائن قيمه الأصلية. 


> إنهاء التحرير 172017016: 


تنهي عملية التحرير وتحفظ في الكائن القيم التي تم إدخالها أثناء عملية 
التحرير. 


>5 واجهة معلومات خطأ البيانات 
IDataErrorInfo Interface‏ 
تقدم معلومات عن الخطأ الذي حدث في السجلء وهي تمتلك الخاصيتين التاليتين: 


57 فز الخطأ :Error‏ 
تعيد نصا يشرح الخطأ الذي حدث في السجل. 


57 ف خطأ العنصر «ررء)1: 
أرسل إلى هذه الخاصية اسم العمودء لتعيد إليك نصا يشرح الخطأ الذي حدث 
في هذا العمود في السجل الحالي. 


ت وا جهة التنبيه بتغير خاصية 
INotifyPropertyChanged Interface‏ 


تطلق الحدث إععمةط٣راإممهإ۴‏ عند تغير قيمة خاصية معينة.. وتمتلك هذه 
الواجهة الحدث التالي: 


# الخاصية تغيرت :PropertyChanged‏ 
ينطاق غندما بك تغيير فى قيمة الخاضية:. والمعائل الثاني و لذا الخدت 
من النوع ›»Property€ChangedEventArgs‏ وهو يمتلك الخاصية 
عط 1م20 التي تعيد اسم الخاصية التي تغيرت. 


24 فئة عرض صف البيانات DataRow View Class‏ 


هذ الففة تثمل الواجهات IEditableObject‏ و IDataErrorInfo‏ 
و »][NotifyPropertyChanged‏ وهي تحتوي على أحد السجلات المعروضة 
في كائن العرض 1(331/167.. ولا يوجد لهذه الفئة حدث إنشاءء ولا يمكنك 
الول خلى دت مها لذ من خلال كان الوک 


وتمتلك هذه الفئة الخصائص التالية: 


37 فين عرض البيانات 1(26]217161: 
تعيد كائن العرض 1021817167 الذي ينتمي إليه الصف الحالي. 


57 لز السجل :R‌0W‏ 
تعيد كائن سجل البيانات 1034818013 الذي يعرضه كائن عرض الصف 
الحالي. 


“57 ف في حالة التحرير 1517036: 
تغيد ووو" إذا كان الل الال ك رور 


<١ 


57 وز هل هو جديد :1!۹N ٥W‏ 
تعيد 116 إذا كان السجلّ الحاليَ جديداء وذلك إذا تم إنشاؤه بواسطة الوسيلة 
..Data View. AddNew‏ مثال: 
Dim Rv = Dv.AddNew(0‏ 
MsgBox(Rv.IsNew) ' True‏ 


العنصر )1 
هذه هي الخاصية الافتراضية Property‏ أأنتهاء(1» وهي تقرأ أو تغير قيمة 
إحدى خانات الصف الحاليء التي يحددها اسم العمود أو رقمه المرسل 
كمعامل.. والمثال التالي يعرض قيم كل الخانات الموجودة في كل صفوف 
كائن العرض 1(7: 

For Each R As DataRowView In Dv 

For I = 0 To Dv.Table.Columns.Count - 1 

MsgBox(R(D) 

Next 

Next 


57 ف نسخة السجل :RowVersion‏ 
تعيد إحدى قيم المرقم 10313103177»1510: التي توضح نسخة السجل 
الو ال 


وتمتلك فئة عرض الصف الوسيلتين التاليتين: 


7# حذف م)م[ء5: 
تحذف السجل الحالي من كائن الععرض› ولهانفس تأثير الوسيلة 
©6116 على السجل الأصلي في جدول البيانات. 


#ا> إنشاء عرض تابع :CreateChild View‏ 

تستخدم هذه الوسيلة إذا كان عارض الصف الحالي ينتمي إلى جدول أساسي 

يرتبط بعلاقة بجدول ثانوي .. وتستقبل هذه الوسيلة اسم العلاقة أو كائن العلاقة 

DataRelation‏ الذي يمثلهاء وتعيد كائن عرض 1(3]21/167 يحتوي على 

كلّ سجلات الجدول الثانوي التابعة لهذا السجل.. والمثال التالي يعيد كائن 

عرض يحتوي على كل الكتب التي ألفها أول مؤلف في جدول الكتب» 

بافتراض أن العلاقة بين جدولي الكتب والمؤلفين اسمها 11]015130015ل: 
Dim Rv As DataRowView‏ 


يداك 


Rv = Ds.Tables("Authors'").DefaultView(0) 
Dim Dv As DataView 
Dv = Rv.CreateChildView('AuthorsBooks'"") 
وقد استخدمنا هذه الوسيلة في المشروع 1(3425615317016» لعرض كتب‎ 
المؤلف المحدد حاليا.. فعند تغير السجل المحدد في جدول عرض المؤلفين»‎ 
وفيه نفعل ما يلي:‎ DataGridView. Row E ter ينطلق الحدث‎ 
نستخدم الخاصية 17207101©:2.»© لمعرفة رقم الصف المحدد حاليا.‎ - 
نظرا لأن رقم الصف في جدول العرضء» هو نفسه رقم الصف في‎ - 
جدول المؤلفين بسبب الربط بينهما ع81010: فسنرسله إلى الخاصية‎ 
الافتراضية 1جوعغ1. 106131114177167 للحصول على كائن عرض هذا‎ 
الصف:‎ 
Dim TbIAuthors = Ds.Tables('"Authors"") 
Dim RowView = TblAuthors.DefaultView(e.RowIndex) 
لاحظ أن رقم كل صف في جدول العرض يظل ثابتا مهما غير‎ 
المستخدم ترتيب الصفوف المعروضة!‎ 
نستخدم الوسيلة 016360111057169 للحصول على كائن عرض‎ - 
يحتوي على كتب المؤلف المحدد حالياء ونعرضها في جدول عرض‎ 
الكتب الموجود في النصف السفلي من النافذة:‎ 
Dim DvBooks As DataView = 
RowView.CreateChildView(' Authors Books") 
DgBooks.DataSource = Dv Books 
لاحظ أنك عندما تبدأ تحرير السجل الجديد الموجود في نهاية جدول عرض‎ 
الكتب» فإن الخانة (41100111, ستأخذ تلقائيا رقم المؤلف الذي ينتمي إليه‎ 
كائن العرض الحالي.. هذا يريحك من كتابة أي كود إضافي» كما يسمح لك‎ 
بإخفاء العمود (4110111/ من الجدول دون قلق» فهو سيأخذ القيمة الصحيحة‎ 
آليا دون أن يشغل المستخدم باله بهذا.. ولإخفاء هذا العمود» أضف هذا السطر‎ 
إلى نهاية الكود السابق:‎ 
DgBooks.Columns(" AuthorID'"). Visible = False 
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TE 
ربط البيانات‎ 
Data Binding 


في تطبيقات قواعد البيانات» كثيرا ما تحتاج إلى عرض بيانات أحد السجلات في 
أدوات موضوعة على النموذج» مع وجود أزرار للتحرك إلى السجل التالي أو 
السجل السابق» ليتمكن المستخدم من التحكم في السجل المعروض حاليا. 

ونظرا لأن فعل هذا يدويا قد يحتاج إلى كود طويل ومرهقء فقد قدمت لك دوت نت 
آلية جاهزة تسمى ربط البيانات 8م81 هاه تتيح لك ربط الكائنات بأدوات 
الويندوز بأقل قدر من الكود. 

ويسمى الكائن الذي يتم ربطه بالأداة باسم مصدر البيانات 5601116 15218.. 
وتشمل مصادر البيانات الأنواع التالية: 


-١ 


الكائنات البسيطة التي تحتوي على بعض الحقول 1"16»105: 

مثل كائن الحجم ءعزا0 5122 الذي يحتوي على الحقلين 1/7104 
و ..Height‏ والمشروع ]نع[ 010100م81 المرفق بأمثلة هذا الكتاب 
يريك مثالا على هذا الربط. 

الكائنات المركبة التي تحتوي على عدة كائنات: 

كالمصفوفات 8113328 التي تحتوي على أرقام أو نصوص أو كائنات 
محددة النوع» والمجموعات 001161055 التي تمثل واجهة القائمة 
+115].. وتعرض الأدوات فى هذه الحالة عنصرا واحدا فقط فى نفس 
اللحظةء وتقدم تقنية الربط الوسائل اللازمة للتحرك إلى العنصر السابق أو 
التالي.. والمشروع Binding ToArray‏ يريك مثالا على هذا الربط. 
الكائنات المعقدة التي تحتوي على مجموعات داخلية: 

وهي الكائنات التي تمثل الواجهة 156.آ]ع181020110 أو الواجهة 
+11577601-15: مثل مجموعة البيانات 1038566 وجدول البيانات 
116 وعرض البيانات 10313171687 ومدير عرض البيانات 
61+ ررونظرا لأن مصدر البيانات يحتوي على أكثر 
من مجموعة داخلية (مجموعة البيانات مثلا تحتوي على أكثر من جدول 
وأكثر من علاقة)» فيجب أن نحدد الخاصية التي سنأخذ البيانات منها 
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(كاسم الجدول مثلا).. وتسمى هذه الخاصية باسم عنصر البيانات 
.Data Member‏ 

وتعرضص الادوات في هذه الحالة سجلا واحدا فقط في نفس اللحظة. وتقدم 
تقنية الربط الوسائل اللازمة للتحرك إلى السجل السابق أو التالي.. 
والمشروع 101(3]8566ع810010 يريك مثالا على هذا الربط. ش 


اجهة ١‏ القايل للارتياط 
IBindableComponent Interfac‏ 


تمتلك هذه الفئة العناصر الأساسية اللازمة لربط الأدوات بمصادر البيانات» وهي: 


7 ف ارتباطات البيانات :Data Bindings‏ 
تعيد نسخة من مجمو عة ارتباطات الأداة «ControlBindingsCoIlection‏ 
تحتوي على كائنات الربط واءهزا©0 عد لم81 التي تستخدمها الأداة 
الحالية.. وسنتعرف على الفئة ع812010 بالتفصيل لاحقا. 


و محتوى الربط :BindingContext‏ 
تقرأ أو تغير كائن محتوى الربط :ع2810175)001 الذي تستخدمه الآداة.. 
وسنتعرف على الفئة 8101080001142 بالتفصيل لاحقا. 


37 تصفير الارتباطات وع1120110)ءو122: 
تقوم هذه الوسيلة بإنعاش القيم التي تعرضها الأداة من خلال الارتباط.. هذه 
الوسيلة ست على ذرحة ملعرينة مق الأهيية. 


# محتوى الربط تغير :BindingContextChanged‏ 
ينطلق هذا الحدث عند تغير قيمة الخاصية .BindingContext‏ 


الجدير بالذكر أن فئة الأداة الأم و0125 00101 التي ترثها جميع الأدوات تمثل 
الواجهة »]BindableCompone†‏ ومن ثم فهي تمتلك جميع العناصر السابقة.. 
هذا معناه أن جميع أدوات الويندوز تصلح للارتباط بمصادر البيانات. 

وتسمى الأدوات التي يتم الارتباط بها باسم الأدوات المرتبطة بالبيانات 
5 12262-1011111: ونظرا لأن كل أداة تمتلك العديد من الخصائص» 
فيجب عليك أن تحدد الخاصية التي تريدها أن تعرض البيانات.. ولا مانع من أن 
تربط أكثر من خاصية من خصائص الأداة» بأكثر من عنصر من عناصر مصدر 


البيانات.. مثلا: يمكنك ربط الخاصية 162 الخاصة بزر الاختيار CheckBox‏ 
بعنصر بيانات نصي وربط الخاصية 0ع1ع06) بعنصر بيانات منطقي 
وتسمى خاصية الأداة التي يتم الارتباط بها باسم عنصر العرض 
Member‏ ayاDisp»‏ لأنها تعرض قيمة خاصية الكائن. 





ملخص: 


مصدر البيانات :Data Source‏ 
هو الكائن الذي يحتوي على البيانات التي يتم ربطها بالأداة.. ومثال ذلك: 
الجدول و8001 في مجموعة البيانات. 


عنصر البيانات :Data Member‏ 
هو الخاصية التي يتم ربط قيمتها بالأداة.. ومثال ذلك العمود )م80 في 
جدول الكتب. 


الأداة المرتبطة بالبيانات :Data-Bound Control‏ 

هي الأداة التي ترتبط بكائن وتعرض بعض بياناته.. مثل مربع النص 
601 أو اللافقة.. لاحظ أن كل الأدوات تصلح لعرض البيانات» 
وعليك اختيار ما يناسب وظيفة برنامجك منها. 


عنصر العرض :Display Member‏ 
هو خاصية الأداة التي ترتبط بعنصر البيانات وتعرض قيمته؛ كالخاصية 
6 في مربع النص أو اللافتة.. لاحظ أن كثيرا من خصائص الأدوات 
تصلح كعناصر عرضء حتى لو لم ير المستخدم قيمتهاء فأحيانا تريد حفظ 
قيمة من مصدر البيانات في الأداة لاستخدامها في وظيفة البرنامج» كأن 

تحفظ رقم المؤلف في الخاصية عه1 بينما تعرض اسمه في الخاصية 1٥×٤‏ . 





وفك نشككم فتن تقنية الربطم جموعة من الفئات الموجودة في نطاق الاسم 
5 .1-775 . دعنا نتعرف على هذه الفئات. 


AR 











4 فئة مجموعة الارتباطات 
BindingsCollection Class‏ 


ترث هذه المجموعة فئة المجمو عة الأساسية 00ع825600116» وهي مجموعة 
تقليدية تمثل الواجهة 10001160110» وتشتق منها العديد من المجموعات الخاصة 
بالارتباطات وأدوات ربط البيانات» والتي سنتعرف عليها لاحقا. 

وتحتوي مجمو عة الارتباطات «0ناءع[اه٣ءعمالم81‏ على كل الارتباطات التي 
تم إنشاؤها بين أداة معينة ومصادر البيانات المختلفة.. وكل عنصر من عناصر هذه 
المجموعة من نوع الفئة 8100108 التي سنتعرف عليها بعد قليل. 

وسكي اال عي ا الد ا نين بال ا 
›BindingManagerBase. Bindings‏ كما سنرى بعد قليل. 


ولا جديد في هذه المجموعة إلا امتلاكها للحدثين التاليين: 


و2 يتم تغيير المجموعة :CollectionChanging‏ 
ينطاق هذا الت عند تحير المجمبر عه والمعائل القاني م الت من 
النوع وع:تخكرامء00116011000286177): وقد تعرفنا عليه من قبل عند 
التعرف على كائن مجموعة الجداول .DataTableCo1lection‏ 


2 تم تغيير المجموعة :ColIlectionChanged‏ 
يتطلى هذ | الكت وعد حدرث الكمدر في البح ها و اذامل ا 
ليذ الحذك سمال لمعامل الحقث اسا 


۷ 


4 فة مجموعة ارتباطات الأداة 
ControlBindingsCollection Class‏ 


ترث هذه المجمو عة الفئة 110ع81001085500116» ويمكن الحصول عليها من 
خلال الخاصية .Contro1. Bindings‏ 

وتفتلك هذه المسراصة اعا القليدية اكه غالت» تكن الريسلة ور لكا 
بها لها الصيغ التالية: 


ك 


-۲ 


الصيغة الأولى تستقبل كائن الارتباط عملم81 المراد إضافته إلى 

المجموعة. 

الصبيخة الثاقية تتفل نة معاسلات: 

- اسم عنصر العرضء مثل ")يرع 1". 

- الكائن +ع06[6 الذي يعمل كمصدر للبيانات» مثل كائن الحجم ©5126. 

- اسم عنصر البيانات.. فمثلاء لو أردت ربط خاصية الارتفاع الخاصة 
بكائن الحجم م81z»‏ فأرسل إلى هذا المعامل النص .."Height"‏ 
ويمكنك إرسال نص فارغ "" إلى هذا المعامل» وفي هذه الكالة 
سترتبط الأداة بالنص الناتج من الوسيلة ToString‏ الخاصة بالكائن.. 
وإذا كان الكائن يحتوي غل كائنات متداخلة (مثل مجمو عه 3 البيانات 
التي تحتوي على جداول» وكل منها تحتوي على أعمدة)» فيجب عليك 
كتابة مسار الخاصية كاملا بدون اسم الكائن.. فمثلا: يمكنك الارتباط 
تا اسم ااا سي خر ن اكت ا كام الاق 
‘"Books.Book"‏ مع إرسال مجمو عة البيانات نفسها إلى المعامل 
الثاني. 

م" فسيتم تطبيق التنسيق 101171236 الخاص بك عند عرض العنصر في 

الأداة. 

الصيغة الرابعة تزيد على الصيغة السابقة بمعامل خامس» يستقبل إحدى قيم 

المرقم »Data Source pdateMode‏ أوضعها في الخاصية 

06 وسنتعرف عليها بعد قليل. 

الفبيكة الخاميية قر يد عل الصصيعة الا جال سات وشو ول 

..Nothing‏ لاحظ أن هذا المعامل من النوع 6+ع[06 ليتيح لك إرسال أية 


۸ 


5- الصيغة السادسة تزيد على الصيغة السابقة بمعامل سابع» يتيح لك إرسال 
نص يحمل التنسيق 10171236 الذي تريد تطبيقه على قيمة عنصر البيانات 
عند وضعها في عنصر العرض. 

۷- الصيغة السابعة تزيد على الصيغة السابقة بمعامل ثامن من نوع الواجهة 
:101 ١ه‏ وضع قيمته في الخاصية 0إمآأوصإه۴ التي 
سنتعرف عليها بعد قليل. 

وتعيد إليك كل هذه الصيغ ‏ ما عدا الصيغة الأولى - مرجعا إلى كائن الارتباط 
5 الذي تم إنشاؤه وإضافته إلى المجموعة. 
وتستطيع استخدام الوسيلة 4010 أيضا لإضافة ارتباط بكائن بسيط حتى لو كان 
مجرد متغير نصي» مثل: 
Dim Name As String = "Mohammad"‏ 
TextBox1.DataBindings.Add("'Text'", Name, "")‏ 
هذا الكود سيجعل مربع النص 162580721 يعرض النص 24ہ haہM.‏ 
كما يمكنك استخدامها لإضافة ارتباط بكائن مكون من أكثر من عنصرء مثل الفئات 
والسجلات.. مثال: 
Dim Sz As New Size(100, 200)‏ 
TextBox2.DataBindings.Add("'"Text", Sz, "Width")‏ 
هذا الكود سيجعل مربع النص ]٥×80×2‏ يعرض الرقم .٠٠١‏ 
ويمكنك استخدام الوسيلة 400 لربط أكثر من مصدر بيانات بنفس الأداة.. هذا 
الكود صحيح: 
TextBox1.DataBindings.Add("'Text'", Name, "")‏ 
TextBox1.DataBindings.Add('Tag", Sz, "Width")‏ 
لكن الوسيلة ل۸ ستسبب خطأ في البرنامج لو حاولت ربط أكثر من مصدر 
بيانات بنفس عنصر العرض في نفس الأداة.. هذا الكود خاطئ: 
TextBox1.DataBindings.Add("'Text'", Name, "")‏ 
TextBox1.DataBindings.Add("'"Text", Sz, "Width")‏ 
لهذا قبل أن تغير ارتباط الخاصية» عليك أن تزيل كائن الارتباط أولا من المجموعة 
باستخدام الوسيلة 12612057 كالتالي: 
Dim Bnd = TextBox1.DataBindings.Add("'"Text'", Name, "")‏ 
TxtName.DataBindings.Remove(Bnd)‏ 
TextBox1.DataBindings.Add("'"Text", Sz, "Width")‏ 
لاحظ كذلك أن عنصر البيانات يجب أن يكون خاصية وليس متغيرا.. بمعنى آخر: 
لا يمكنك ربط الأداة بحقل 11610 من حقول الكائن.. تذكر أن الحقل هو متغير عام 
Variable‏ 20116 معرف على مستوى الفئة» مثل: 
Class Student‏ 


۹ 


Public ID, Age As Integer 
Public Name As String 
End Class 
الآن لو عرفت كائنا من فئة الطالب وليكن:‎ 
Dim Std As New Student With { .ID = 1, .Age = 15, 
.Name = "Ahmad"'} 
فإن محاولة ربط أي حقل خاص بالكائن 560 (وليكن الحقل مصه) بأية أداة‎ 
ستؤدي إلى حدوث خطأ في البرنامج:‎ 
TxtId.DataBindings.Add("'"'Text"", Std, "Name") 
لهذا عليك تغيير الحقول العامة في فئة الطالب لتصير خصائص.. كل ما عليك هو‎ 
التي‎ Auto Implemented Properties استخدام الخصائص ذاتية التعريف‎ 
بإضافة الكلمة ا۲عم٥ قبل اسم المتغير»‎ ٠١٠١ قدمتها فيجيوال بيزيك دوت نت‎ 
دون الحاجة إلى كتابة كود الخصائص كالتالي:‎ 
Class Student 
Public Property ID As Integer 
Public Property Age As Integer 
Public Property Name As String 
End Class 
الآن لو جربت ربط أي خاصية من خصائص الكائن †8» فسيعمل كل شيء على‎ 
ما يرام.. والمشروع 812012810001604 يريك الكود الكامل لربط خصائص فئة‎ 
الطالب بمربعات النصوص.. وعليك عند فحص هذا المشروع أن تلاحظ ما يلي:‎ 

-١‏ أن أي تغيير تجريه على مربعات النصوص سيؤثر على الكائن الأصلي 
4. ولو جربت تغيير بيانات الطالب في مربعات النصوص وضغط 
الزر "بيانات الطالب" فستعرض الرسالة القيم الموجودة في مربعات 
النصوصء رغم أن الكود المكتوب في حدث ضغط الزر يعرض بيانات 
المتغير 51601. 

۲- إذا حاولت أن تكتب قيمة خاطئة في أي مربع نص ككتابة حروف في مربع 
النص الخاص برقم الطالب» فسيتم إلغاؤها بمجرد مغادرته.. هذا معناه أن 
تقنية ة الربط تجيز البيانات تلقائيا اقبل مغادرة الأداةء فإذا كائك شت خطا 
وإعادته إلى قيمته السابقة. 

كما يمكنك أيضا الارتباط بكائنات معقدة» مثل مصفوفة تحتوي على عناصر من 
نوع فئة التلميذء أو كائنات أكثر تعقيدا مثل مجموعة البيانات التي تحتوي على 
جداول» بكل منها أعمدة يعتبر كل عمود منها مصفوفة (لأن به صفوفا) ويصلح 
كنض انات والمقال الالى بنش كان ار قاط وتفه الى مجموغنة ارتياطات 
مربع النصء ليجعله يعرض اسم الكتاب الحالي في جدول الكتب: 


a0 


Dim B As Binding = TextBox1.DataBindings.Add(""Text'", 
Ds, "Books.Book") 
ويمكن فعل نفس الشيء أيضا بالكود التالي:‎ 
Dim B As Binding = TextBox1.DataBindings.Add("Text"", 
Ds.Tables("'Books'"), "Book'"") 
ويريك المشروع :81010167130 مثالا طريفا على هذاء حيث سنجعل مربع‎ 
نص يعرض اسم الكتاب الحالي» ومربع نص آخر يعرض اسم مؤلفه.. وسنعرض‎ 
جدول الكتب كله في جدول عرض 103300110117167 الذي سنتعرف على طريقة‎ 
ربطه لاحقا.‎ 








الجميل في الأمر أن المستخدم كلما انتقل من صف إلى آخر في جدول العرض» 
يعرض مربعا النص اسم الكتاب الموجود في هذا الصف واسم مؤلفه تلقائياء وبدون 
أن نكتب أي كود!. . السبب في هذا أن جدول العرض يغير الصف الحالي في كائن 
الارتباط تيقوم للقائيا يتحديت القيم المعروضة في جميع الأدوات المرتبطة به!.. 
لكن لكي تعمل هذه الطريقة» يجب أن يكون مصدر البيانات المرتبط به جدول 
العرض هو نفسه مصدر بيانات مربعي النص.. هكذا مثلا: 
DataGridView1.DataSource = Ds‏ 
DataGridView1.DataMember = "Books"‏ 
TxtBook.DataBindings.Add("'"'Text"", Ds, "Books.Book'")‏ 
TxtAuthor.DataBindings.Add(""'Text'"", Ds, "Books.Author")‏ 
أو يمكن استخدام جدول الكتب كمصدر بيانات للاختصار: 
DataGridView1.DataSource = Ds.Books‏ 
TxtBook.DataBindings.Add("'"Text"", Ds.Books, "Book'"")‏ 
TxtAuthor.DataBindings.Add("'"Text'", Ds.Books, "Author'"")‏ 


<١ 








لگن ارد قات ان بج الإرنايج يعمل اكل صحيي لأن مصعر بات جدرل 
العرض (وهو 1(05.80015) مختلف عن مصدر بيانات مربعي النص (وهو و(1): 
DataGridView1.DataSource = Ds.Books‏ 
TxtBook.DataBindings.Add("'"'Text"", Ds, "Books.Book'"")‏ 
TxtAuthor.DataBindings.Add("'Text'", Ds, "Books.Author'"")‏ 
كذلك فإن الكود ا عي سا ع ا > لأن مصدر 
زوفو :(Ds.Books‏ 
DataGridView1.DataSource = Ds‏ 
DataGridView1.DataMember = "Books"‏ 
TxtBook.DataBindings.Add("'"Text"", Ds.Books, "Book'"")‏ 
TxtAuthor.DataBindings.Add("'Text'", Ds.Books, "Author'"")‏ 


وشمتلك مجفوعة الأرتياطات الختضائضن الحديذة الثالية: 


5 زوز الأداة :Control‏ 
تعيد الأداة التي تنتمي إليها مجموعة الارتباطات الحاليّة. 


57 ف المكون القابل للارتباط :BindableComponent‏ 
تعيد واجهة المكون القابل للارتباط +معم0م18120131»001 التي تنتمي 
إليها مجموعة الارتباطات الحالية. 


"8 الطريقة الافتراض ةلت ديت مص ر البياتات 
:DefaultDataSource Update Mode‏ 
تحدد القيمة الافتراضية للخاصية ءلM0ء Data SourceU pda‏ لكل كائن 
ربط في المجموعة» وهي تأخذ إحدى قيم المسرقم 
Data 00‏ التي سنتعرف عليها لاحقا. 


Ai 


Binding Class أ الارتباط‎ ê 


تقوم هذه الفئة بربط كائن يعمل كمصدر بيانات» بإحدى الأدوات» بحيث يأخذ 
عنصر العرض فى الأداة قيمة عنصر البيانات فى الكائن تلقائياء وتغير قيمة 
أحدهما كلها تغيرت قيمة الآخن: 
ولحدث إنشاء هذه الفئة نفس صيغ الوسيلة «ControlBindingsCollection.Add‏ 
ما عدا الصيغة الأولى التي تستقبل كائن ارتباط ع منلطاظ. 
افترض أن لدينا مصفوفة أعداد صحيحة معرفة على مستوى النموذج كالتالي: 
Dim A(0 As Integer = {1, 2, 3, 4}‏ 
سنعرف الآن كائنا يربط الخاصيّة )×1 في مربّع النص بعناصر هذه المصفوفة: 
Dim B As New Binding("Text'", A, "")‏ 
TextBox1.DataBindings.Add(B)‏ 
لاحظ أن حدث الإنشاء استقبل ثلاثة معاملات: 
- اسم خاصية الأداة وهي هنا ")يرهع1". 
- مجموعة البيانات وهي هنا المصفوفة ۸. 
- اسم عنصر العرض وقد تركناه فارغا لربط الكائن نفسه (المصفوفة).. لكن لو 
كنا نتعامل مع سجل الطالب 510101016 Student‏ متلا (كما فعلنا في 
المشروع «(BindingToArray‏ »> فيمكن أن نرسل إلى هذا المعامل اسم أي 
حقل من حقوله؛ كالاسم "٥ه"‏ أو العمر "مع۸".. أو غير ذلك. 


وتمنحك الفئة 8100108 الخصائص التالية: 
37 ف المكون القابل للارتباط :BindableComponent‏ 


تعيد واجهة المكون القابل للارتباط 64 0م1م18120361600 التي تمثلها 
الأداة التي ينتمي إليها الارتباط الحالي. 


59 زوز الأداة :Control‏ 
تعيد الأداة 01م00 التي ينتمي إليها الارتباط الحالي. 


وخ اسم الخاصية :PropertyName‏ 

تقرأ أو تغير اسم عنصر العرض. 
57 فخ مصدر البيانات ع12262560111:0: 

تعيد الكائن Object‏ الذي يعمل كمصدر للبيانات في هذا الارتباط. 
57 ف معلومات عنصر الربط :BindingMember1Info‏ 


<Y 


»BindingMemberInfo Structure‏ تحتوي على معلومات حول عنصر 
البيانات.. وسنتعرف على هذا السجل لاحقا. 


557 فل أساس مدير الربط ع81201087/121228611385: 
تعيد كائن أساس الارتباط ع7/1328611935ع812010» الذي يتيح لك التحكم 
في الارتباط الحالي.. وسنتعرف على الفئنة BindingManagerBase‏ 
بالتفصيل لاحقا. 


57 فيز هل هو مرتبط ع151812011: 
تعيد عنم[ إذا كان الارتباط فعالاء وتعيد 116 إذا تم إيقاف الارتباط عن 
العمل مؤقتا. 


7 طريقة تحديث الأداة :ControlUpdateMode‏ 
تحدد كيفية تحديث ر العرض» عندما تتغير قيمة عنصر البيانات.. وتأخذ 
هذه الخاصية إحدى قيمتي المرقم ControlUpdateMode‏ التاليتين: 


OnProperty hanged‏ | يتم تحديث قيمة عنصر العرض فور تغير قيمة 
عنصر البيانات.. هذه هي القيمة الافتراضية. 











ال القيمة الفارعة :NullValue‏ 


..Nothing‏ لاحظ أن هذه الخاضصية ستكون بلا فائدة إذا كانت الكاسيعة 


.None القيمة‎ 6100 


٤ 











وخ طريقة تحديث مصدر البيانات :DataSource Update Mode‏ 
تأخذ إحدى قيم المرقم ل0 Mء hata Source pda‏ التالية: 


Never‏ لا تحديث و البيانات.. هذا يعني أن أي تغيير 
ر ا ا و ا 
17 إيتم تغيير قيمة عنصر البيانات بمجرد تغيير قيمة عنصر 

Changed‏ العرض.. فمثلا لو كتب المستخدم في مربع النص» فان 
10 الا يتم نقل التغيير من عنصر العرض إلى عنصر 
البيانات إلا عند انطلاق حدت تمام التحقق من الصحة 
114 ؟؛ وذلك عند مغادرة الأداة أو 
هذه هي القيمة الافتراضية. 











3 القيمة الفارغة لمصدر البيانات :DataSourceNulIV alue‏ 
تحدد القيمة التي ستوضع في عنصر البيانات» إذا كانت لعنصر العرض القيمة 
..Nothing‏ لاحظ أن هذه الخاصية ستكون بلا فائدة إذا كانت للخاصية 
.None ةميقll DataSourceUpdateMode‏ 


وخ نص التنسيق :FormatString‏ 
تستقبل نصا يعرف صيغة التنسيق الذي سيستخدم لتنسيق البيانات ة قبل وضعها 
في عنصي رک کا قد ر فين حن دس الأرقاء واوا 
التي تعرفنا عليها في ملاحق كتاب برمجة إطار العمل. 


وخ تفعيل التنسيق :Formatting Enabled‏ 
لع 239ههظه د“ SO‏ 
الخاصية FormatString‏ على البيانات قبل وضعها في عنصر العرض. 














وعا معلومات التنسيق 1”01:122111210: 


تقرأ أو تغير واجهة مزود التنسيق 1۴٥۲21۴٥۷1٥۲‏ التي يستخدمها كائن 
الارتباط.. لقد عرففا في كتاب برمجة إطار العمل أن الففات 
«Date TimeFormatInfo ‘NumberFormatInfo‏ 01111210 تمثل 
واجهة مزود التنسيق e۲‏ 0۲2۴01 ۴]»ء لكن بالنسبة لهذه الخاصية» 
يمكنلك استخدام نسخة من الفئة CultureInfo‏ للتحكم في اللغة والثقافة التي 
ستستخدم عند تنسيق البيانات.. وفي الوضع الافتراضي تتعامل هذه الخاصية 
مع الثقافة (اللغة) المعرفة على جهاز المستخدم. 


ويمتلك كائن الربط الوسيلتين التاليتين: 


قراءة القيمة :Read Value‏ 
تجبر الأداة على عرض قيمة عنصر البيانات. 


كتابة القيمة :Write Value‏ 
تجبر الأداة على وضع قيمة عنصر العرضء في عنصر البيانات. 


ويمنحك كائن الارتباط الأحداث التالية: 


2 تنسيق 1"0111121: 


ينطلق قبل كتابة قيمة عنصر البيانات في عنصر العرضء ليسمح لك بتنسيق 
البيانات قبل أن تعرضها الأداة. 

والمعامل ع لهذا الحدث من النوع وعتشامء005611187: وهو يمتلك 
الخاصيتين التاليتين: 


9 ون | 126511601506 | تعيد كائن النوع عم15» الذي يمثل نوع بيانات 


٠‏ عنصر العرض. 
ما | تقرأً أو تغيير البيانات التي سيتمٌَ ومن ف 


عنصر العرض.. هذه الخاصية من النوع 








06601 للتعامل مع أنواع البيانات المختلفة. 





مثلاء يمكنك أن تعرض البيانات في الأداة بتنسيق التاريخ القصير كالتالي: 
e.Value = CType(e.Value, Date).ToString("d/MM/yy")‏ 


:P a۲٥ تحويل‎ 3 


AR 














ينطلق عندما تتغيّر قيمة عنصر العرض.. فإذا كنت قد غيرت تنسيق البيانات 

باستخدام الحدث وص إه۴؛ فاستخدم هذا الحدث لاستخلاص البيانات الأصليّة 

وإعادتها إلى النوع المناسب لوضعها في خاصية الكائن. 

والمعامل ع لهذا الحدث مماثل لذلك الخاص بالحدث السابق.. انظر كيف 

نستعيد التاريخ من النص الذي نسقناه ه في الحدث السابق* 
e.Value = Date.Parse(e.Value.ToString)‏ 


# انتهى الربط mpleteږBindingCo:‏ 
ينطلق هذا الحدث بعد وضع قيمة عنصر البيانات في عنصر العرضء أو بعد 
وضع قيمة عنصر العرض في عنصر البيانات. الال اا و لهيذا 
الحدث من النوع eteEven{ArgsاompلBinding»›‏ وهو يمتلك 
الخضنائضن التالية: 


ق وہ Bindi‏ | تعيد كائن الارتباط ع010م81 الذي أطلق الحدث. 
2 ير Binding‏ تخبرك باتجاه عملية الربط وهي تعيد إحدى قيمتي 
Complete‏ | المرقم eteContextاp Binding om‏ التاليتين: 
:Contro1€p date - ¡| Context‏ يتم تحديث الأداة. 
:Data0urceJpdate -‏ يتم تحديث مصدر 
البيانات. 
يو( 81201125 | توضح حالة عملية الربط» وهي تعيد إحدى قيم 
eteاComp‏ | المرقم Binding Compete State‏ التالية: 
State‏ - وو6نعن9: نجحت عملية الربط. 
:Data Error -‏ فشلت عملية الربط بسبب خطأ 
في البيانات.. في هذه الحالة يرفض مصدر 
البيانات أو الآداة القيمة الجديدة» لكن لا يحدث 
:Exception -‏ فشلت عملية الربط وحدث خطأ 
في البرنامج. 
E‏ 710116 | تعيد نصا يصف الخطأ الذي حدث في عملية 
الربط. 
5 ور | Exception‏ | تعيد كائن الاستثناء ٣0م ۴×٥٥‏ الذي يحتوي 
على تفاصيل الخطأ الذي حدث عند ربط البيانات. 














والمثال التالي يعرف كائن ربط ٤ءء‏ زا0 8100128 بين الخاصيّة )×1 لمربّع 
نص» وبين العمود جمم8 في جدول الكتب في مجموعة البيانات 105: 


۷ 




















Dim B As New Binding('"'Text", Ds, "Books.Book") 


هذا ا قاط لن هة خا من الد إلة ]ذا اشفا الى مح عار قاط 
559 الخاصة بمربّع النص» كالتالي: 


TextBox1.DataBindings.Add (B) 


أسماء الكتب المختلفة في مربع النص.. وعلى كل حال» ستجد هذا مطبقا في 
المشروع .ViewAndEditBooks‏ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


۸ 


اح سجل معلومات عنصر الربط 
Structure‏ 1210نت ددع 1211ل ساخا 


يحتوي هذا السجل على معلومات عن عنصر البيانات.. ولا تتضح فائدة هذا السجل 
كائنات متداخلة.. في هذه الحالة عليك إرسال مسار الكامل لاسم الخاصية التي 
تعمل كمعتصيز ميانات+ إلى حدك إنشاء هذا الکن مثال: 

Dim Bmi As New BindingMemberInfo ("Books.Book") 
حيث 80015 هو اسم جدول الكتب» و )800 هو الحقل الذي سيتم عرض قيمته‎ 
في الأداة.. لاحظ أن هذا المسار لا يحتوي على اسم الكائن (وهو مجموعة البيانات‎ 
في مثالنا هذا)» فهذه المعلومة موجودة في كائن الربط عمالم81 الذي ينتمي‎ 5 
.BindingMemberInfo إليه السجل‎ 
ويمكنك أيضا الحصول على نسخة من هذا السجل باستخدام الخاصية‎ 
.Binding.BindingMemberInfo 


i 57‏ عنصر الربط :BindingMember‏ 
تيد السار العامل لخر البياناك:...وقي المكال الذي كيريناء سيد هذه 
الخاصية النص: ع200125.800[1 . 


57 فر حقل الربط :BindingField‏ 
تعيد اسم عنصر البيانات (بدون المسار الكامل).. هذا يعني أنها ستعيد النص 
2001 في المثال السابق. 


57 يفون مسار الربط :BindingPath‏ 
تك سار عنصير البياناكه (يذون اسم الخاضية).. .ولق استكهدينا هذه الخاضية 
مع المثال السابق» فستعيد النص 80015. 
وى كان الكاتن یط ,فر البداتات کن لد میا کے نفدم اال رین 
القيمة العائدة هي اسم الخاصيةء مثل 78/1040 لو كان الارتباط بكائن الحجم 
.Size‏ 


2 فئة محتوى الربط BindingContext Class‏ 


<۹ 


هذه الفئة تمثل واجهة المجموعة 1001161105» وهي تعمل كمجموعة للقراءة فقط 
تحتوي على كائنات مدير الربط ع611325 810011028013128 الخاصة بأداة معينة.. 
وسنتعرف على الفئة ©2101081/21286113256 بعد قليل. 
فالخل على ةا مين هذه ةا ر الكاضتية 
1-2206 وووالمثال التالي يعيد إليك مجموعة تحتوي على 
كائنات أساس مدير الربط للنموذج: 

Dim BC As BindingContext = Me.BindingContext 
لاحظ أن مجموعة محتوى الربط ]81020180011462 الخاصة بالأداة الحاوية‎ 
تحتوي على كل كائنات مدير الربط ع010511328611325م81 الخاصة بكل‎ 
فى‎ 8)٤ الأدوات الموجودة على هذه الأداة الحاوية.. هذا يعنى أن محتوى الربط‎ 
المثال السابق سيحتوي على كائنات أساس الربط لكل الأدوات الموضوعة على‎ 
النموذج (بشرط أن تكون داخلة في ارتباطات).. هذا يفيدك في تسهيل كتابة الكود‎ 
عندما توجد العديد من الأدوات المرفطة كل الفولاج.‎ 


57 ف العنصر 22رع)1: 
هذه هي الخاصيّة الافتراضية» وهي تعيد مدير الربط 
6135 الموجود في المجموعة تبعا للمعاملات المرسلة.. 
ولهذه الخاصية صيعتان: 

.١‏ الصيغة الأولى لها معامل من النوع «Object‏ يستقبل مصدر البيانات 
الذي تريد الحصول على مدير الربط الخاص به.. والكود التالي يوقف 
الارتباطات بين مجموعة البيانات و12 وكل الأدوات الموجودة على 

Me.BindingContext(Ds).SuspendBinding( ) 

؟. الصيغة الثانية تزيد على الصيغة السابقة بمعامل نصي» يستقبل مسار 
عنصر البيانات.. هذا مفيد إذا كان الكائن يحتوي على العديد من 
1© 0111811021825 استخدمنا الجملة التالية للحصول على مدير 
الربط: 

Dim Bm = Me.BindingContext(Ds Books, "10015 ''(‏ 
لاحظ أن مدير الربط 81 في هذه الحالة يتعامل مع جدول الكتب» لهذا 
نستطيع استخدام الخاصية Bnm.Position‏ للتحكم في الكتاب 

المعروض حاليا في الأدوات.. بينما لو استخدمت الجملة التالية: 
Dim Bm = Me.BindingContext(Ds Books)‏ 


cT. 


فستحصل على مدير ربط يتعامل مع مجموعة البيانات نفسهاء ونظرا 
لأنها تحتوي على العديد من القوائم الداخلية (مثل مجموعة الجداول 
ومجموعة العلاقات وغيرهما)» فلن يستطيع مدير الربط ٍ8 في هذه 
الحالة التعامل مع جدول الكتب» وستشير الخاصية 01111 8.٤‏ إلى أن 
هناك عنصرا واحدا فقط في مدير الربط (وهو مجموعة البيانات 
نفسها)» ولهذا لن تستطيع الانتقال إلى سجلات أخرى باستخدام 


الخاصية .Bm.Position‏ 
كما تمتلك هذه المجموعة الوسيلتين التاليتين: 


7# تحتوي على 5مذة020©: 
تعيد عن[ إذا كانت المجموعة تحتوي على مدير الربط المحدد في 
المعاملاك. . وليذة الرسيلة نفس :صيككي الخاصية الاق سي وا 


© > تحديث الربط :UpdateBinding‏ 
أرسل إلى هذه الوسيلة مجموعة محتوى الربط 2ع181018004: وكائن 
الربط عملم الذي تريد إزالته من مجموعة أخرى وإضافته إلى 
المجموعة المحددة في المعامل الأول. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


5 


2 فئة أساس مدير الريط Binding ManagerBase Class‏ 


هذه الفئة أساسية مجردة 1255© 8356 2,4651214 ومنها تشتق الفئات التي تعمل 
كمدير للربط.. والفئات التاليتان ترثان هذه الفئة: 
.١‏ فئة مدير التسلسل .CurrencyManager Class‏ 
؟. فئة مدير الخاصية .PropertyManager Class‏ 
ولتعريف شر نين هذا الكاتن» استخدم الصيغة الثالية: 
Dim BM As BindingManagerBase‏ 
ولوضع نسخة جديدة من مدير الربط في هذا المتغيرء يمكنك استخدام الخاصية 
5 من كائن الارتباط ع010م81.. مثال: 
Dim Bnd = TextBox1.DataBindings.Add("'"Text'"", Obj, "")‏ 
BM = Bnd.BindingManager Base‏ 
لاحظ أن نوع المدير الذي سيوضع في المتغير 83/4 يتوقف على نوع الكائن.. فلو 
كان كائنا بسيطا فسيحتوي المتغير 8١M‏ على نسخة من مدير الخاصية 
:1 الذي يتحكم بالارتباط بعنصر البيانات.. أما إذا كان الكائن 
مركبا ويحتوي على قائمة من العناصرء فسيحتوي المتغير 8١‏ على نسخة من 
مدير التسلسل 1أوع0101620371/122) الذي يتحكم في ربط قائمة عناصر الكائن. 


وتمتلك هذه الفئة الخصائص الثالية: 


7 فز الارتباطات Bindings‏ : 
تعيد مجموعة الارتباطات 812010550001160 التي تحتوي على جميع 
الارتباطات التي تشترك فيها الأداة الحالية. 


:Count العدد‎ iT 
إذا كان‎ ١ تعيد عدد العناصر المشتركة فى الارتباط.. هذا العدد سيكون دائما‎ 
الكائن بسيطا وتم الارتباط بإحدى خصائصه.. أما إذا كان الكائن معقدا وتم‎ 
الارتباط بقائمة عناصر موجودة داخله؛ فان هذه الخاصية تعيد عدد عناصر‎ 
هذه القائمة (مثل عدد سجلات الجدول إذا كان الارتباط بعمود في أحد جداول‎ 

مجموعة البيانات). 


يدرك 


وخ الموضع 20510101: 
تقرأ أو تغيّر موضع العنصر الذي تعرضه الأداة حاليًا.. هذا مفيد عند 
الارتباط بكائن معقد يحتوي على قائمة من العناصرء ففي بدء الارتباط 
ستوضع في عنصر العرض قيمة أول عنصر في هذه القائمة» ويمكنك بعد 
هذا أن تستخدم الخاصية 205101 لعرض أي عنصر آخر في القائمة.. 
والمثال التالي يعرض في مربع النص ثالث كتاب في جدول الكتب: 

Dim Bnd As New Binding("'Text", Ds, "10015.15001'(‏ 
TxtBook.DataBindings.Add(Bnd)‏ 
Bnd.BindingManagerBase.Position = 2‏ 
وقد استخدمنا هذه الخاصية في التطبيق 2ء1م 81,1,4524 لنتيح للمستخدم 
التحرك عبر خانات مصفوفة التلاميذ وعرض بيانات كل تلميذ في مربعات 

النصوص» وذلك باستخدام أزرار الاتجاهات أسفل النموذج: 1 


عا ادا 1111111111111 سملن 


الرقم 8 
الحمر 14[ 


[mahmood الاسم‎ 


ااه الال . IE‏ 





المريح في الأمر أننا لا نحتاج إلى تغيير الموضع لكل مربع نص على 
النموذج» فكل ما علينا هو الحصول على مدير الربط الخاص بمصفوفة 
التلاميذ من خلال محتوى الربط الخاص بالنموذج كالتالي: 
Dim Bm As BindingManagerBase = Me.BindingContext(Std)‏ 
وبهذا يؤدي تغيير قيمة الخاصية 817.2051]10 إلى تغيير العنصر الحالي 
المعروض في جميع أدوات النموذج. 
كما يتيح البرنامج 810015052313162 للمستخدم كتابة رقم الخانة مباشرة 
في مربع النص الذي يتوسط الأزرار (واسمه و1<620)؛ وعندما يضغط 


TT 


1 من لوحة المفاتيح يتم عرض التلميذ الموجود في هذه الخانة.. لاحظ 
أن الخاصية 7051100 ترفض أي موضع غير صحيح دون أن يحدث خطا 
في البرتامج:. لهذا لو جربت أن تكتب الرقم ١١.‏ مثلا في مريع النص.وتضخط 
»Enter‏ فإن الخاصية 2051100 ستنتقل تلقائيا إلى آخر خانة مسموح بها 
وهي الخانة رقم ٤‏ في هذا المثال. 


57 زور الحالي :Current‏ 


تعيد الكائن ٥زط0‏ المرتبط حاليا بعنصر العرض.. وفي حالة الارتباط 
بكائن بسيط يحتوي على عدة خصائص (مثل كائن الحجم ع512)» تعيد هذه 
الخاصية هذا الكائن» أما عند الارتباط بكائن معقد يحتوي على قائمة من 
العناصرء فإن هذه الخاصية تعيد العنصر الحالي في القائمة 
(الموجود في الموضع الذي تحدده الخاصية 0051]10). 


57 فر هل الربط متوقف :IsBindingSuspended‏ 


تعيد ع1 إذا كان الربط بين الأداة ومصدر البيانات متوقفا حاليا. 


وتمتلك هذه الفتة الوسائل التالية: 


ب 


ف 


إضافة جديد 00171 4: 

تضيف عنصرا جديد إلى قائمة عناصر مصدر البيانات.. وتسبب هذه الوسيلة 
خطأ في البرنامج إذا كانت الأداة مرتبطة بكائن بسيط لا يحتوي على قائمة 
داخلية» أو إذا كان الكائن مصفوفة.. وعند استخدام هذه الوسيلة مع صفوف 
البيانات» تكون حالة السجل الجديد هي 40060.ع120175121: ولن تتم 
إضافته إلى قاعدة البيانات إلا عند تحديثها. 


حذف من موضع )1211014: 

تحذف العنصر الموجود في الموضع المرسل كمعامل.. وتسبب هذه الوسيلة 
خطأ في البرنامج إذا كانت الأداة مرتبطة بكائن بسيط لا يحتوي على قائمة 
داخلية؛ أو كان الكائن مصفوفة أو كان لا يمثل الواجهة 56ز.آع1810010.. 
وعند استخدام هذه الوسيلة للتعامل لحذف صف بيانات» فسيتم تغير حالة حالته 
إلى Deleted‏ ولن يتم حذفه من قاعدة البيانات إلا عند تحديثها. 

إلغاء التحرير الحالي :CancelCurrentEdit‏ 

لعي ع التخريس الخالئة وتعيد إلى السجل فة الأضلية.,وليين ليذ 
الوسيلة أي تأثير إلا على الكائنات التي تمثل الواجهة ئ1Editab]leObjec‏ 
مثل فئة سجل العرض .DataRow View Class‏ 


< 


7# إنهاء التحرير الحالي :EndCurrentEdit‏ 
تنهي عمليّة التحرير مع إبقاء التغييرات التي حدثت للسجل.. وليس لهذه 
الوسيلة أي تأثير إلا على الكائنات التي تمثل الواجهة ect‏ [12:01]8616016 
مثل فئة سجل العرض .DataRow View Class‏ 


2# معرفة خصائص العنصر sعi) :GetIte Prope‏ 
تعيد مجمو عة واصفات الخصائص PropertyDescriptorCo1lecti0on‏ 
التى تصف خصائص المجمو عة المشتركة فى الارتباط.. مثلا: عند الارتباط 
بحقل اسم الكتاب في جدول الكتب» ستحتوي هذه المجموعة على واصف 
الخصائص إ0ام1إءsمrtyDمpدPr‏ لكل عمود في جدول الكتب.. والمثال 
التالي يعرض اسم أول حقل في السجل الحالي» ويعرض قيمته: 
Dim BM = Bnd.BindingManagerBase‏ 
Dim PD = BM.GetItemProperties(0)‏ 
MsgBox(PD.Name) ' ID‏ 
MsgBox(PD.GetValue(BM.Current))‏ 
حيث ستعرض الرسالة الأولى اسم الحقل 15 بينما ستعرض الرسالة الثانية 
قيمة الحقل (11 في السجل الحالي. 
#أ- إيقاف الارتباط :SuspendBinding‏ 
توقف الارتباط بين الأدوات ومصدر البيانات مؤقتا.. وقد استخدمنا هذه 
الوسيلة لإيقاف الربط في التطبيق ره10۸۲۲ع«لم81» وذلك عند إزالة 
علامة الاختيار من مربع الاختيار ×80)ءعطC‏ الموجود أسفل النموذج. 


ا مواصلة الارتباط :ResumeBinding‏ 
تستأنف الارتباط بين الأدوات ومصدر البيانات. 


وتمتلك هذه الفئة الأحداث التالية: 


۶ الربط اكتمل :BindingCom plete‏ 
ممائل للحدث .Binding.BindingConmplete‏ 


2 الموضع تغير :PositionChanged‏ 


ينطلق إذا تعبرت قيمة الخاصية وم تاتون والمعامل الكائي ه لهذا الحدث 
من النوع وع1)مء587: الذي لا يحمل أية معلومات هامة عن الحدث. 
وقد استخدمنا هذا الحدث في التطبيق 810110/11357: لتحديث الموضع 
المعروض في مربع النص TxtPos‏ الموجود أسفل الوا كلما تغير. 
بالإجراء الغ تحن 1 باستخدام الجملة 00 في حدث تحميل 
النموذج كالتالي: 

AddHandler Bm.PositionChanged, 

AddressOf Bm_ PositionChanged 


7 السجل الحالي تغير :CurrentChanged‏ 
ينطلق إذا تغيّرت قيمة الخاصية 116ع11ن0). 

© العنصر الحالي تغير :CurrentItem Changed‏ 
ينطلق إذا تغيرت حالة العنصر الحالي الذي تعرضه الأداة.. يحدث هذا إذا 
تغيرت قيمة إحدى خصائص هذا العنصرء أو إذا تم استبداله أو حذفه. 

© خطأ البيانات :Data Error‏ 
ينطلق إذا قام مدير الربط بمعالجة خطأ حدث أثناء عملية الربط.. والمعامل 
الثاني e‏ 2 اد من النوع yy‏ 0 


ع لع ا ب 


احرف 


42 فئة مدير الخاصية PropertyManager Class‏ 


هذه الفئة ترث الفئة ©ع81201187/123128611825» وهي تعمل كمدير يتحكم في ربط 
كائن بسيط له عدة خصائص ولا يحتوي على قائمة عناصر داخلية. 
ولا تمتلك هذه الفئة أية خصائص أو وسائل أو أحداث جديدة غير ما ترثه من الفئة 
الآ 

م 


42 فئة مدير التسلسل CurrencyManager Class‏ 


هذه الفئة ترت الفئة ع1812011817/1231128611325» وهي تعمل كمدير يتحكم في ربط 
وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة العنصرين التاليين: 


ف القائمة ٠1,15)‏ 
هذه الخاضية من قوع واجية القائمة اوا هي فيد القائنة الداخلية الت 
يحتويها الكائن. 

:Refresh إنعاش‎ > 


تعيد ملء مصفوفة العناصر المرتبطة.. استخدم هذه الوسيلة عند الارتباط 


A4 


ربط الأدوات فى وقت التصميم: 

يقدم لك مصمم النماذج 106518061 ۴٥۲۳‏ في دوت نت تسهيلات كثيرة لربط 
الأدوات في وقت ا » لتقليل الكود الذي تحتاجه لأداء هذه العملية. ولگي ترئ 
هذا عملياء ابدأ مشروعا جديدا وأسمه ›VieW A۴180 0ks‏ وصمّم واجهة 
استخدامه كما في الصورة التالية: 


اماد 
mem‏ 3 
E‏ 


E NT 





أضف إلى النموذج موصل بيانات اسمه 1(3,4115011300[125» واجعله يستخدم 
الاستعلام التالي للحصول على أسماء المؤلفين وأسماء كتبهم: 
SELECT Authors.Author, Books.ID, Books. Book‏ 
FROM Authors INNER JOIN‏ 
Books ON Authors.ID = Books.AuthorID‏ 
أنشئ مجمو عة بيانات محددة النوع 10312561 60م197 من هذا الموصل بالطريقة 
المعهودة» وأسمها 5ع1(5,41140113001» وأضف نسخة منها إلى النموذج اسمها 
.DsAuthorBooks 1‏ 
الآن» نريد ربط مربّعات النصوص بهذه المجموعة.. اتبع الخطوات التالية: 
- حدد مربّع النص الذي سيعرض رقم الكتاب» ومن نافذة الخصائص حذد 
المقطع المسمّى عمالم81 هه .. ستجده في بداية الخصائص» خروجا 
عن الترتيب الأبجديّ للخصائصء وسيكون موضوعا بين قوسين. 
- اضغط العلامة + المجاورة للمقطع «DataBinding‏ لإسدال خصائص 
الأداة التي يمكن ربطها بمجموعة البيانات.. بالنسبة لمربّع النصَ» ستجد أن 
بإمكانك ربط الخاصيتين عه و 2ه1.. في الغالب يتم ربط الخاصيّة 
عه برقم السجل (11» وذلك لتسهيل التعامل مع الحقل عند الحاجة.. ولكن 
في مثالنا هذاء سنعرض هذا الرقم في الخاصيّة )»م1 لتظهر للمستخدم. 


TA 


- حذد الخاصيّة )ر1'» واضغط زر الإسدال الموجود في خانة القيمة.. 
ستعرض لك القائمة المنسدلة اختيارين: 

| لإلغاء ربط الخاصية بأي‎ :N0صn8‎ -١ 

؟- :0ther Data Sources‏ ولو أسدلت 


Properties اد‎ 
TextBox1 System. Windows. كترم‎ Text 


1 E+ 


5 (DataBindings) 





(nonê) 51 . 

عتصرين فر عيين. |* sks1 - Authors.ID‏ 

(N SOher 005 Sis :Project Data Sources أ.‎ 
7 r0 ata Sources : 








"5 لاجم"‎ List Instances 


الببانات العامة للمشروع»› مثل يفوم ق 
Authors e‏ 3 
فئات مجمو عات البيانات محددة Author‏ 1 

1110 


النوع مثل ..DsAuthorBooks‏ 
ولو اخترت أيا من هذه الفئات» 
فسيتم تعريف نسخه ة منها 
لاستخدامها في النموذج الحالي. 
ب. :۴0rm1 1156 Instances‏ ستجد تحت هذا الفرع نسخ الأدوات 

الموضوعة على النموذج الحالي» والتي تصلح للعمل كقوائم 
البيانات 1(54114011300151.. لو أسدلت عناصر هذه المجموعة» 
فستجد تحتها أسماء الجداول المعرفة في مجموعة البيانات محددة 
النوع. . وستجد في مثالنا هذا جدولا واحدا اسمه 11005رء وذلك 
لأن موصل البيانات قد منح الجدول الناتج من استعلام الربط ورزمل 
1157 الاسم الافتراضي 411015/.. أسدل حقول هذا الجدولء 
واختر الحقل 10. 

001 ومربع النص الثالث بالحقل 0۲طاںA.‏ 

الآن أنهينا ربط أدواتنا بمصدر البيانات» بحيث لو ملأنا مجموعة البيانات 

بالسجلات» فستظهر قيم حقول السجل الحالي في مربّعات النص» بدون أن نكتب 

أي كود لفعل هذا.. وكلما تحركنا من سجل إلى آخرء يتمّ عرض قيم حقول السجلٌ 

الجديد في الأدوات آليّا. 

عند هذه النقطةء لو شغلت المشروع وضغطت زر تحميل البيانات» فستظهر قيم 

السجل الأول في مربّعات النص» كلّ حقل في مربّعه الذي حددناه. 

نريد الآن أن نكتب كود الأزرار التي تسمح للمستخدم بالتنقل بين سجلات مجموعة 

البيانات.. سيكون الأمر بسيطاء فكل ما علينا هو استخدام مدير الربط 


> Add Project Data Source, 
Te Currently data bound to ID, 


<۹ 


15 والذي يمكننا الحصول عليه من خلال الخاصية 
1200 الخاصة بالنموذج كالتالي: 
Dim Bm As BindingManagerBase =‏ 
Me.BindingContext(DsAuthorBooks1, "Authors'"")‏ 
الآن تستطيع تغيير الموضع كما تريدء باستخدام الخاصيتين Position‏ و Count‏ 
التابعتين لمدير الربط.. مثا في زر الانتقال إلى السجل التالي» استخدمنا الكود: 
If Bm.Position > Bm.Count - 1 Then‏ 
Bm.Position += 1‏ 
LbPosition.Text = Bm.Position + 1 & " / " & Bm.Count‏ 
End If‏ 
لاحظ أن محاولة تغيير السجل الحالي قد تؤدي إلى حدوث خطأ في البرنامج» 
وذلك لأن مدير الربط سيفحص مربعات النصوص» فإن كانت بعض قيمها تغيرت»› 
فسيحاول حفظها في مجموعة البيانات» وسيحدث خطأ إذا كان المستخدم قد أدخل 
قيمة غير مناسبة لأحد الحقول.. لحل هذه المشكلةء استخدم المقطع 
Catch‏ :119 لمعالجة أي خطأ من هذا النوع» وفي المقطع ب[ع]02 استخدم الجملة 
التالية لإلغاء تحرير السجل الحالي (الذي سبب المشكلة): 
Bm.CancelCurrentEdit( )‏ 
لاحظ أن هذا الكود سيعيد قيم كل مربعات النصوص إلى ما كانت عليه.. سيكون 
هذا مستفزا للمستخدم للغاية لو كان عدد مربعات النصوص كبيرا وكان الخطأ ناتجا 
عن قيمة خاطئة في واحد منها فقط.. لهذا سيكون من الأذكى أن تلغي تحرير مربع 
النص الذي سبب المشكلة؛ أو أن تكرك القيه ع كما هي» وتترك للمستخدم 
لفك نظر ك ةا الى أن كل فر اك ی سردو الم تكد ع رات 
النصوص يتم حفظها في مجموعة البيانات (وليس في قاعدة البيانات)» لهذا على 
المستخدم ضغط زر الحفظ لإرسال التغييرات من مجموعة البيانات إلى قاعدة 
البيانات.. هذا الزر يستخدم أمر التحديث 0236م11] الخاص بموصل البيانات» لكن 
هذا يحتاج إلى بعض العمل مناء لأن موصل البيانات لا ينتج أمر التحديث إذا كان 
أمر التحديد يعيد حقولا من أكثر من جدولء تاركا لك أنت التحكم في الحقول التي 
تريد تحديثها وكيفية تحديثها.. ونظرا لأننا سنسمح في هذا البرنامج بتحديث الحقل 
15.1001 فقطء فسنستخدم أمر التحديث التالي: 
UPDATE Books‏ 
SET Book = @Book‏ 
WHERE ID = @Original ID‏ 
وستجد تعريف هذا الأمر ومعاملاته في حدث تحميل النموذج. 


:Binding List Boxs ربط مربعات القوائم‎ 


رأينا حتى الآن كيف نربط الأدوات البسيطة كمربعات النصوص بمصادر البيانات 
المختلفة.. لكن ماذا لو أردنا ربط أدوات أكثر تعقيدا مثل القائمة 1,15]90:2آ والقائمة 
المركبة ComboBox‏ وقائمة الاختيار CkeckedListBox؟‏ 

لو حاولت استخدام كائن الربط لربط مصدر البيانات بالخاصية وجرره]1 لهذه 
الأدوات» فكل ما ستحصل عليه هو رسالة خطاء تخبرك أنه لا يمكن الارتباط 
بالخاصية وور م)] لأنها للقراءة فقط! 

إذن فما الحل؟ 

في الحقيقة» هناك طريقة أخرى لربط مربعات القوائم بمصادر البيانات» فهذه 
الأدوات لا تحتاج إلى المرور من سجل إلى آخرء فهي قادرة على عرض كل 
السجلات دفعة واحدة» ومن ن أجل هذا فهي تمتلك خصائص مجهزة لهذا الغرض» 
وهي: 


ونج مصدر البيانات ع1(24250111:2: 
ضع في هذه الخاصية الكائن الذي تريد الارتباط به. 


وخ عنصر العرض :Display Member‏ 
تستقبل نصاء يحدد اسم خاصية الكائن التي سيتم عرض قيمته في القائمة.. 
وفي المشروع '8]15]1041183 81010 جعلنا قيمة هذه الخاصية 
"Name"‏ لهذا تعرض القائمة أسماء الطلاب. 
لاحظ أنك لو تركت هذه الخاصية فارغة فستعرض القائمة النص الذي تعيده 
الوسيلة ع105111' الخاصة بكل عنصر من عناصر مصدر البيانات. 


259 فيز القيمة المحددة :Selected Value‏ 
تعيد القيمة المحددة حاليا في القائمة» وهي تتوقف على قيمة الخاصية 
ValueMember‏ . 


وا عنصر القيمة :Value Member‏ 

امتقل نضا يحدد اسم خاصية الكنائق التي سنك فر اوها عد استخدام 
الخاصية ..Selected Value‏ وفي المشروع  BindingListToArray‏ 
جعلنا قيمة هذه الخاصية "14" لهذا فإن الخاصية 0172106ع01ه1ع5 تعيد رقم 
الطائف: الخد حاليا فى القائمة»«وينكتك تخرية هذا بخ الزر الو جود 
أسفل القائمة. 1 

ولو تركت الخاصية :773116301 فار غة؛. فإن الخاصية 
07211 م0160 > ستعيد العنصر المحدد في القائمة حاليا مثلها مثل الخاصية 
.SelectedItem‏ 


Ea 


تعال نستخدم هذه الخصائص في تطوير المشروع 015 257167410110180 فهو 
يبدو غفا لو حخاولت استخدامه لعرضن البيانات من قو اعد انات الشبخمة: حت 
إن التحرّك بين آلاف السجلات واحدا بعد آخر يبدو نوعا من العبث.. لهذا لا بذ من 
إنشاء واجهة أكثر ملاءمة لهذا الوضع.. وكحل مبدئي» تعال نستخدم قائمة مركبة 
0101301 لعرض أسماء الكتب» بحيث يختار المستخدم منها اسم الكتاب 
مباشرة بدلا من ضغط أزرار الانتقال.. صمّم النموذج ليبدو كما في الصورة» وهو 
موجود في المشروع 80011156 المرفق بهذا الكتاب: 


 اصااعأ‎ 
اضر‎ Î iu iS لسم الككاب‎ 


رقم الكتاب 


و فاروق جويدة 





تعرف طبعا كيف تربط مربعي النص اللذين يعرضان اسم المؤلف ورقم الكتاب.. 
ما يهمنا الآن هو كيفية ربط القائمة المركبة. 

حذد القائمة المركبة»ء ومن نافذة الخصائص اختر الخاصيّة 2102125011106 
واضغط زر الإسدال الموجوذ قى خائة قيمتهماة ومن القائسة المشسيدلة اختر 
Other Data Sources‏ ثم «Form1 List Instances‏ ثم .DsAuthorBooks1‏ 
بعد هذا انتقل إلى الخاصيّة DisplayMember‏ في نافذة الخصائص» واضغط زر 
الإسدال الموجود في خانة قيمتهاء واختر الجدول وإ0طانںAء‏ ومن حقوله اختر 
الحقل ع1]800[1. 

إذا شغلت التطبيق الآن» وضغطت زر تحميل البيانات» فستجد أن القائمة المركبة 
قد امتلأت بأسماء الكتب.. المدهش أنك لو اخترت اسم أي كتاب من القائمةء 
فسيؤدي هذا إلى تغيير السجل الحالي» ومن ثم سيظهر رقمه واسم مؤلفه في مربّعي 
النص تلقائياء وبدون أن تكتب سطرا واحدا من الكود لفعل هذا! 

حسن.. نريد الآن تطوير المشروع السابق» بحيث نعرض أسماء المؤلفين في قائمة 
مركبة» ونعرض كتب المؤلف المحدد حاليا في قائمة مركبة أخرى» كما هو موضح 
في الصورة التالية: 


E 





اتبع هذه الخطوات: 


-١ 
-۲ 
3 


-۷ 


أنشئ مشرو عا جديدا اسمه .AuthorsBooks_ Lists‏ 

أنشأ موصل بيانات اسمه ١إ0طا‏ ں5۸ يعيد أسماء المؤلفين وأرقامهم. 

أنشأ موصل بيانات اسمه 123180015 يعيد أسماء الكتب وأرقامها 
وأسعارها.. ويعيد أيضا الحقل (41150111, لكي نستخدمه في إنشاء علاقة 
بين الجدولين. 

أنشئ مجموعة بيانات محددة النوع اسمها 105411501580015 تحتوي 
على الجدولين. 

اضغط الأداة 154110151300151 في صينية المكونات بزر الفأرة 
الأإسنء ومن القائمة الموضعية اضسغط الأمر 
..Edit in Dataset Designer‏ ستظهر لك نافذة مخطط ,2311]1.. أنشئ 
علاقة بين الجدولين اسمها 411015_128001, كما فعلنا من قبل. 

بالنسبة للقائمة المركبة التي ستعرض أسماء المؤلفين» ومربّع النصّ الذي 
سيعرض رقم المؤلف» لن تختلف طريقة ربطهما بمجموعة البيانات في شيء 
عن المثال السابق. 

أما بالنسبة للقائمة المركبة التي ستعرض أسماء الكتب فسيختلف الأمر قليلا.. 
حذد الخاصيّة DataSource‏ في نافذة الخصائص» وضع فيها القيمة 
1 نم حذد الخاصيّة eme‏ ayMاisp(»‏ واضغط 
زر الإسدال الموجود في خانة القيمة.. هذه المرة لا تختر جدول الكتب» بل 
اختر جدول المؤلفين 11015/.. ستجد ضمن عناصره الفرعيّة عنصرا 
جديداء هو 11015_1800[15خ.. هذا العنصر هو اسم العلاقة التي أنشأناها.. 
أسدل فروع هذا العنصر.. ستجد تحته أسماء حقول جدول الكتب.. اختر 
الحقل ع[800.. بهذا لن تعرض قائمة الكتب كل الكتب الموجودة في قاعدة 


EY 


البيانات» بل ستعرض فقط الكتب التي تنتمي إلى المؤلف الحالي من خلال 
ا 4 د 
لاحظ أنك تستطيع أداء هذا من الكود باستخدام الجملة التالية: 
CmbBook.Display Member =‏ 
"Authors.Authors_ Books.Book"‏ 
۸- بالنسبة لمربّع النص الذي سيعرض رقم الكتاب» اربط الخاصيّة 1٥×)‏ 
بالحقل 15 الموجود في العلاقة 4115015_1800165, تحت جدول المؤلفين 
5 م.. وافعل شيئا مشابها بوط مربع النص الأخير بالحقل 
.Authors. Authors Books.Price‏ 
لاحظ أنك تستطيع أداء هذا من الكود كما يلي: 
TextBox1.DataBindings.Add('Text",‏ 

DsAuthorsBooks1, "Authors.Authors_ Books.ID'"") 
TextBox2.DataBindings.Add('Text", 

DsAuthorsBooks1, '"' Authors.Authors_Books.Price'"") 
وأخيراء اكتب الكود الذي يملأ مجموعة البيانات بسجلات الجدولين في حدث‎ -۹ 
DaAuthors.Fill(DsAuthors Books1, "Authors'"") 
DaBooks.Fill(DsAuthorsBooks1, "Books"") 
الآن لو جرّبت البرنامج» فلا ريب أئك ستتيه دهشة وسعادةء فلديك واجهة استخدام‎ 

رائعةء تعمل بطريقة مثاليّةء في برنامج لم نكتب فيه أكثر من سطرين من الكود! 


لاحظ أننا لا نملك طريقة مباشرة لاستخدام العلاقة 615 _ 5 بطريقة 
عكسية في عملية الربط.. مثلا: : لا تستطيع أن تجعل مربع نص يعرض مؤلف 
الكتاب الحالي بالجملة التالية: 
TextBox1.DataBindings.Add('Text"",‏ 
Ds, '"Books.Authors Books.Author'"")‏ 
فهذه الجملة ستسبب خطأ في البرنامج» لأن العنصر 41111015_180015, ليس 
جزءا من جدول الكتب!.. إن عملية الربط تعتبر العلاقة جزءا من الجدول الرئيسي 
فقطء وليس الجدول الفرعي! 
وقد واجهتنا هذه المشكلة في المشروع :8100108162130 الذي أنشأناه في بداية 
هذا الفصل» فنحن في هذا المشروع نعرض جدول الكتب في جدول عرض 
107167 9 ونريد أن نربط مربع النص باسم مؤلف الكتاب المحدد حاليا 
في جدول العرض.. في هذه الحالة لا يمكننا أن نستخدم الجملة التالية: 
TextBox1.DataBindings.Add('Text"",‏ 
Ds, "Authors.Authors_ Books.Author'"")‏ 


٤ 


لأنها ستعرض في مربع النص اسم أول مؤلف فقطء ولن يتغير مهما تغير الكتاب 
الحالي.. السبب في هذا أن كائن الربط الخاص بجدول العرضء يتعامل مع سجلات 
جدول الكتب فقطء وليست له أي علاقة بجدول المؤلفين! 
ولحل هذه المشكلة عرفنا عمودا إضافيا اسمه :01)ن1ى وجعلنا خفياء وجعلناه 
يحمل اسم مؤلف الكتاب الحالي من خلال العلاقة بينهما كالتالي: 
و(2117506)511:1115) Dim Col As New DataColumn(" Author'"",‏ 
"Parent.Author'", MappingType.Hidden)‏ 
ثم أضفنا هذا العمود إلى جدول الكتب كالتالي: 
Ds.Books.Columns.Add(C o1)‏ 
TxtAuthor.DataBindings.Add("'Text'", Ds, "Books.Author'"")‏ 
ولو جربت المشروع فستجده يعمل على ما يرام. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


-5- المعالج ١‏ تهيئة مصادر البيانات 


Data Source Configuration Wizard 


يستخدم هذا المعالج لإضافة مصادر البيانات إلى مشروعك.. ويمكنك تشغيله 
بضغط قائمة البيانات 34111 هه( من شريط القوائم الرئيسية أعلى مصمم 
النموذج» وضغط الأمر 50116 10348 7216537 ۸14.. ستظهر لك نافذة اختيار 
نوع مصدر البيانات» الموضحة في الصورة: 





Data Source Configuration ¥#izard 2× 
1 Choose a Data Source Type 
لل تلات‎ 


Yhere vill the application get data from? 


ا !ا 


Service Object 


Lets you connect to a database and choose the database objects For your application, 








Fish | Cancel | 
2 


هذه النافذة تتيح لك اختيار أحد أنواع مصادر البيانات التالية: 
١‏ قاعدة بيانات :D 4)48 44e‏ 
ينتيح لك هذا النوع إنشاء مصدر بيانات يتعامل مع قاعدة بيانات» حيث يتم 
إنتاج مجموعة بيانات محددة النوع Daket‏ 6م1577 وموصلات 
الجداول اللازمة للتعامل مع كل جدول من جداولها. 
- خدمة :Service‏ 
..W eb Service‏ هذا النوع خارج نطاق هذا الكتاب. 
۳- كائن )ىع ز0: 
يتيح لك هذا النوع إنشاء مصدر بيانات يتعامل مع أي كائن في مشروعك.. 
ثلا لو عرفت فئة اسمها «Students‏ فيمكنك جعلها مصدر بيانات» 
باختيار هذا النوع ثم ضغط )× واختيارها من النافذة التالية كما هو 
موضح في الصورة: 
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Data Source Configuration Wizard لا‎ 


a Select the Data Objects 


سورت 


Expand the referenced assemblies and namespaces to select your objects, IF an object is missing from a 


referenced assembly, cancel the wizard and rebuild the project that contains the object, 
What objects do you want to bind to? 
Add Reference... | 








J WindowsApplication1 
E] Wi {} windowsApplication1 
7 92 Form1 
WV @$ student 
E] TC {} WindowsApplication1 My 
] | 24 myApplication 
] | 44 mysettings 


لل 


IV Hide system assemblies 


< Previous | EXE > || لضع‎ Cancel ر‎ 
7 





ويمكنك اختيار أي فئة من فئات إطار العمل لاستخدامها كمصدر بيانات لو 
ارفك لفل ها أزل علا م ةا لاخ ار مسن مرسع الاخايبار 
Hide System Assemblies‏ لتظهر فئات إطار العمل في القائمة.. وإذا 
أردت عرض فثئات من خارج مشروعكء فاضغط الزر 
Add Reference‏ وأضف مرجعا إلى المكتبات التي توجد بها.. وبعد أن 
تختار مصدر بيانات أو أكثر من القائمة» اضغط الزر طینہا۴. 
- تطبيق :Share Point‏ 
يتيح لك هذا النوع إنشاء مصدر بيانات يناسب تطبيق 
..SharePoint 0‏ هذا الموضوع خارج نطاق هذا الكتاب. 


دعنا الآن نتعامل مع النوع الأكثر ملاءمة لنا هنا.. اختر النوع 


56 واضغط الزر )×عN..‏ ستظهر لك نافذة اختيار نموذج قاعدة البيانات 
Database Model‏ كما في الصورة: 


5 


Data Source Configuration ¥#izard اا‎ 


15 Choose a Database اع100؟‎ 





What type of database model do you want to use? 


2 للا 





Dataset Entity Data 
Model 


The database model you choose determines the types of data objects your application code uses, 


< Previous | FS | Cancel | 
2 








ستجد في هذه النافذة خيارين: 


أ- :DataSet‏ 
يتم إنشاء مجموعو بيانات محددة النوع» واستخدامها كمصدر بيانات. 


ب- :Entity Data Model‏ 
هذا الاختيار مناسب للمشاريع التي تستخدم LinQ-To-SQL‏ 
و ›Entity Framework‏ وسنؤجله إلى الكتاب القادم بإذن الله. 


اختر 10312561 واضغط .Nex‏ 

ستظهر لك نافذة الاتصال بقاعدة البيانات»ء وقد تعرفنا عليها كثيرا من قبل.. اختر 
الاتصال بقاعدة بيانات الكتب 800125.71011» واضغط .Next‏ 

ستظهر لك نافذة تسألك إن كنت تريد حفظ نص الاتصال في إعدادات المشروع 
5 أم لا.. اترك علامة الاختيار كما هيء وعدل الاسم الذي تريد أن 
تستخدمه لحفظ نص الاتصال فى الإعدادات لو أردت» واضغط مجع]7. 

انتظر لحظة إلى أن يتم الاتصال بقاعدة البيانات وتحميل مكوناتها.. ستظهر لك 
نافذة تتيح اختيار كائنات قاعدة البيانات التي تريد التعامل معهاء وستجد فيها كل 
الجداول والعروض والإجراءات المخزنة المتاحة في قاعدة البيانات» كما تبين 
الصورة: 


۸A 





Data Source Configuration ¥izard لا‎ 


1 Choose Your Database Objects 
م‎ ] 


سے 





which database objects do you want in your dataset? 


El WM EŞ Tables 

[` I Authors 
IV Î Books 
TG] Classes 

] I countries 
] O Puplishers 
] ١ I sales 

] ] TempBooks 
ly views 

lp stored Procedures 
ع‎ lf Functions 











Fl Fl 
3 8 8 FF F&F 


FT Enable local database caching 


DataSet name: 


[BooksDataset 





< Previous | ext > Cancel | 
و0‎ 


اختر جدولي المؤلفين والكتب في مثالنا هذا.. لاحظ أن وضع علامة الاختيار 
بجوار اسم الجدول يحدد كل أعمدته. . لكنك تستطيع ضغط العلامة + المجاورة 
لاسم الجدول لإسدال أ عمدته» حيث يمكنلك إزالة علامة الاختيار المجاورة لبعضهاء 
وبهذا توفر على برنامجك تجميل بيانات لا ضرورة لها. 
ويمكنك تعديل الاسم الافتراضي لفئة مجموعة البيانات محددة النوع» من خلال 
مربع النص السفلي. 
تستطيع الآن أن تضغط :11151 لإنهاء المعالج السحري وإنشاء مجموعة البيانات» 
أو يمكنك وضع علامة الاختيار أمام الاختيار: 

Enable Local Database Caching 
هذا الاختيار يتيح حفظ بعض بيانات الجداول على جهاز المستخدم لتكون جاهزة‎ 
للاستخدام» وذلك إذا كان معدل تغيرها في قاعدة البيانات بطيئاء مما يقلل من عدد‎ 
مرات الاتصال بالخادم» وبالتالي يحسن أداء وسرعة البرنامج.. إذا اخترت هذا‎ 
الخيار» فعليك أن تضغط )× لمواصلة المعالج.. لكننا سنترك هذا إلى الكتاب‎ 
القادم.. اضغط [1”1015 لإنهاء المعالج.‎ 
سيؤدي هذا إلى إضافة الملف 800151(343561.250 إلى المشروع.. ولو نقرت‎ 
المؤلفين وجدول الكتب والعلاقة بينهماء كما ستجد فيه موصل جدول المؤلفين‎ 
_وموصل جدول الكتب 1ع1م800110218403.‎ 1010161: 
متصفح مصادر البيانات:‎ 
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لو فتحت القائمة الرئيسية 12242 وضغطت الأمر «Show Data Sources‏ 
فسيظهر لك متصفح مصادر البيانات 1ع101م1<2 Data Sources‏ كما هو موضح 


في الصورة. 

هذه النافذة تعرضص جميع مصادر 

البيانات الموجودة في المشروع 

(مثل مجموعات البيانات).. وستجد BooksDataSet‏ ها 5 

فيهااسم مجموعة البيانات Authors‏ ع 

BoksDataBooks‏ التي أنشأها ID‏ اله 

معالج مصادر البيانات» ولو أسدلت Author‏ ال 

عناصرهاء فستجد تحتها جدولى CountryID‏ اله 

المؤلفين والكتب» ولو أسدلت كلا Phone‏ اله 

منهما فستجد تحته أسماء أعمدته. About‏ اله 

ويتيح لك متصفح مصادر البيانات Books‏ تن يع 

إضافة مصادر بيانات جديد وتعديل > ا 5 

الفضياكق العو دود تة ولك ية DataGridView‏ 

خلال الأزرار التي تظهر أعلاه؛ Details‏ 3 

9 [None] وهي:‎ 
Customize... 





el Publish_Date 
al Ver 





New Data Source 1‏ 44 4: يؤدي ضغط هذا الزر إلى تشغيل المعالج 
السحري لمصادر البيانات. 


:E dit Data Source With Designer Ê‏ يودي ضغط هذا الزر فتح 

:Configure Data Source With Wizard `‏ يؤدي ضغط هذا الزر إلى 
تشغيل المعالج السحري لمصادر البيانات» لكنه يعرض نافذة اختيار كائنات 
قاعدة البيانات مباشرة» لتستطيع إضافة الجداول أو حذفها. 

ا 

1 رطووقع#: يؤدي ضغط هذا الزر إلى إنعاش مصدر البيانات» للتفاعل مع 
أية تغييرات حدثت في قاعدة البيانات. 

البيانات» فبمجرد سحب اسم أي حقل من متصفح مصادر البيانات وإلقائه على 

النموذج» يتم إضافة العديد من الأدوات إلى النموذج كما هو موضح في الصورة: 


{00 





Form1.vb [Design]* x 


OOS.‏ سملن 


:14 4 0 of {O0} > i # اها “ا‎ 


8110 


a" BooksDataSet 7577 BooksBindingNavigator 
BOOKS ان ا ا‎ 8 TeDEAdapterManager 


BooksBindingSource ٠‏ ق 





وكما تلاحظ من الصورةء فإن الأدوات التي أضيفت هي: 

-١‏ لافتة تعرض اسم الحقل» اسمها البرمجي 751.351 حيث > هو اسم الحقل. 

.2216:2010:2 مربع نص يعرض قيمة الحقل» اسمه البرمجي‎ -١ 

۳- نسخة من فئة مجموعة البيانات 70015103125616 لاستخدامها فى 
الحصول على البيانات. 

-٤‏ نسخة من موصل الجدول الذي يوجد به الحقل.. فمثلا لو سحبت الحقل 
5001 فسيضاف موصل الجدول 161م800125181»403 إلى صينية 
المكونات. 

5- نسخة من مدير التوصيل 1أوع 137161731312 كره131' للتحكم تحديث 
مجموعة البيانات. 

5- أداة مصدر الربط ع0ع181015901 لاستخدامها في ربط الأدوات 
بمجموعة البيانات.. وسنتعرف على هذه الأداة بعد قليل. 

۷- نسخة من الأداة BindingNavigator‏ لتتيح للمستخدم التحرك عبر 
السجلات.. وسنتعرف على هذه الأداة بعد قليل. 

۸- يتم إنتاج كود تحميل البيانات في حدث تحميل النموذج 8 أآليا.. متلا 

يتم إنتاج الكود التالي ليملا حدول المؤلفين بالبيانات من قاعدة البياكات: 
Me.AuthorsTableAdapter.Fill (Me.BooksDataSet. Authors)‏ 

4- يضاف زر لحفظ التغييرات إلى شريط موجه الربط 

101 ع 01مة8: ويضاف الكود التالي إلى حدث ضغط هذا الزر: 


٥1 


Me.Validate0 
Me.AuthorsBindingSource.EndEditO0 
Me.TableAdapterManager. Update All(Me.BooksDataSet) 
أليس شيئا رائعا؟.. أنت لا تحتاج إلى فعل أي شيء تقريباء سوى سحب الحقول‎ 
وإلقائها على النموذج لتحصل على برنامج كامل الوظيفة!‎ 
ويمكنك ربط الحقل بالأداة بطريقة أخرىء» وذلك بوضع الأداة على النموذج أولاء‎ 
ثم سحب الحقل من نافذة المصادر وإلقائه على الأداة.. هذا سيضبط خصائص الأداة‎ 
تلقائيا لتعرض قيمة هذا الحقل.‎ 
كما أنك لست مجبرا على عرض قيمة الحقل في مربع نصء فلو حددت اسم الحقل‎ 
في متصفح مصادر البيانات» فسيظهر زر إسدال بجواره ولو ضغطته فستظهر‎ 
قائمة موضعية»؛ بها أسماء الأدوات التى يمكنك استخدامها لعرض قيمة الحقل.. ولو‎ 
اخترت القيمة 6م710 فلن يتم وضع أدوات لعرض هذا الحقل عند إلقائه على‎ 
النموذج.‎ 
وفي الوضع الافتراضي يكون مربع النص 120202 هو الأداة المستخدمة‎ 
لعرض قيمة الحقل» لكنك تستطيع اختيار أية أداة أخرى لجعلها تعرض قيمته. . ولو‎ 
لم تجد الأداة المناسبة بين الأدوات الظاهرة في القائمة؛ فاضغط الأمر‎ 


Customize‏ الموجود في نهاية القائمة لعرض النافذة الموضحة في الصورة: 
opis Looo sS. 2×‏ 


E: Environment Data type: 
[Projects and Solutions [integer | 
IH: Text Editor 
E1 Windows Forms Designer Associated controls: 
Data UI Customization TextBox (default) 
Numeric lpDown 


ComboBox 
Label Clear Default 
LinkLabel 


ListBox 

Chart 
CheckBox 
CheckedListBox 
DateTimePicker 
DomainlpDown 
|] Image 
















Set DEfaUl 
General 





لكا KI‏ لكا لكا لكا لكا 1100Û Û‏ 





مع , نامل مابابا, مموع عد بك نه رعواء زطعممز1عئق 0 System. Windows, Forms.‏ 


Learn how to add custom controls... 


[ Show all settings Cancel | 


في هذه النافذة يمكنك اختيار نوع البيانات من القائمة المنسدلة «Data Type‏ 
لتظهر في القائمة السفلية الأدوات التي يمكنها عرض هذا النوع من البيانات» حيث 
ستجد علامة الاختيار بجوار الأدوات المسموح باستخدامهاء ويمكنك وضع علامة 


toY 





الاختيار بجوار أية أدوات أخرى تريد أن تسمح باستخدامها مع هذا النوع؛ ثم 
تضغط 0[6. 
وتتيح لك نافذة مصادر البيانات التعامل مع الجدول كله دفعة واحدة.. فلو حددت 
اسم الجدول 4111015 في متصفح مصادر البيانات» فسيظهر زر إسدال بجواره؛ 
- عمه<: لا يتم وضع أية أدوات على النموذج عند إسقاط الجدول عليه. 
rid View -‏ ta6Gه(:‏ لو اخترت هذا الخيار» وسحبت جدول المؤلفين وألقيته 
على النموذج» فسيضاف جدول عرض إلى النموذج» وسيحتوي على أعمدة 
لعرض حقول جدول المؤلفين.. ويؤدي ضغط أزرار التحرك الموجودة 
على شريط موجه الربطء إلى تغيير السجل المحدد حاليا في جدول 
الغررطي كنا أن :ضغط زو !العاف سك اسل الففده خالا م ل 
زر الإضافة سيضيف سجلا جديدا إلى نهاية جدول العرض. 
- 1268115: لو اخترت هذا الخيار» وسحبت جدول المؤلفين وألقيته على 
النموذج» فستضاف أداة عرض خاصة بكل حقل على حدة» وبجوارها لافتة 
تحمل اسم هذا الحقل.. ويختلف نوع أداة العرض الخاصة بكل حقل على 
حسب الاختيار الذي حددته لكل حقل (كما شرحنا سابقا).. مثلا: قبل أن 
تسحب جدول المؤلفين» عليك أن تغير نوع أداة عرض الحقل 9[ إلى لافتة 
Lab‏ حتى لا تسمح للمستخدم بتغيره» كما يمكنك اختيار العنصر None‏ 
مع الحقل (0011213/11) لمنع عرض رقم دولة المؤلف.. بعد هذا لو سحبت 
جدول المؤلفى و الفا علي ارد ف يتم وضع الأدوات عليه كما في 
الصورة: 


8 ج‎ gg HEE 


iM 4|0 of {O} |> I | x ها‎ 


HB Label1 


Author: ا‎ 
Phone: 
About: 





الأمر رائع فعلاء فقد كان تصميم النماذج في مشاريع قواعد البيانات يستهلك معظم 
وقت إنتاج البرنامج. . لكن الآن صار الأمر في منتهى البساطة» فأنت تحصل على 
معظم العمل بالسحب والإسقاطء مع الكثير من الكود المولد آليا! 


tor 


وبنفس الطريقة يمكنك إضافة نماذج أخرى إلى المشروع؛ وإسقاط جداول أخرى 
عليها. 

لك ناقدة مصادر البيانات ميزة ¡ إضافية ما هي -- لك بعرض البيانات 
..Books‏ هذا العنصو أحبيف ليمثل العلاقة المعرفة بين جدول المؤلفين وجدول 
الكتب في مجموعة البيانات +8001251(034856.. ولو أسدلت العنصر 800[25» 
هد الخد كل کل الكتب: ولى نكا کے على اعراج در 
بعانات كنت المؤلك الحالي, . لاحظ أنه من غير المنطقي عرض كل حقل فرعي 
على حدة إذا كنت تتعامل مع علاقة واحد بمتعدد 1/123137- -026-10).. فالمناسب في 
مثالنا هذا استخدام جدول لعرض كتب المؤلف الحالي» كما ترى في الصورة: 


im Jx 


1 of4|> [x< a 


توفيق الحكيم]ً Author:‏ 
كك Phone:‏ 
وروائي مصدري راحل|ً About:‏ 


| AuthorID | PublisherID | ClassID 





وستجد هذا التصميم في التطبيق 122125015571210 المرفق بهذا الكتاب. 

لو شغلت هذا التطبيق فسيمكنك الانتقال بين المؤلفين باستخدام شريط موجه الربط 
حيث ستعرض الأدوات العلوية بيانات المؤلف الحالي» وسيعرض الجدول السفلي 
كتب هذا المؤلف.. هذا مشروع 7135161-10618115 كامل يعمل بكفاءة دون أن 
نكتب فيه حرفا وعدا من الكود!.. أليس شيئا مثيرا؟ 

لاحظ أن وجود العمود (41100111 في جدول العرض لا معنى له.. لكن للأسف». 
لو حاولت إزالة هذا العمود باختيار ©7026 من القائمة المنسدلة للحقل Autho115‏ 
قبل سحب عنصر العلاقة 80018 على النموذج» فلن تنجح.. فجدول العرض 
يعرض كل الأعمدة شئت أم أبيت» وتكون كل هذه الأعمدة أعمدة مربعات 











النصوص DataGridView TextBoxColumnn‏ مهما كان نوع الأداة التي 
اخترتها لعرض قيمة الحقل!.. لهذا علبك تكديه حدول العركن واستخدام فد 
الخصائص لحذف هذا العمود من مجموعة أعمدة جدول العرض 5تتطتنتاآه © 
2 وسنتعرف على جدول العرض بالتفصيل في الفصل التالي. 
زر غم كل التسهيلات: التي تمنحها لذا نافذة مضادر البيانات.. إلا أنها أخيانا: لا تعطيفًا 
بالضبط ما نريده. . مثلا: لو أردت عرض أي حقل في قائمة 1.156 أو قائمة مركبة 
01301 »؛ فإن سحب الحقل وإلقائه على النموذج يربط الخاصية 1٥×)‏ 
التابعة لهاتين الأداتين بالحقل» ولا يتم ملؤهما بقيم الحقل! 
ولحل هذه المشكلة .عليك التدخل: بدوياة ن تدا افد الفشيتاضي ازا ال ا 
بالخاص ية غإبزه1؛ واس تخدام الخامطميتين DataSource‏ 
و Data Member‏ بدلا منها. 
والتطبيق 713516110612115 يريك مثالا على هذا.. لإنشاء مثل هذا التطبيق» افعل 
مايلي: 
- من نافذة مصادر البیانات» اسحب الحقل 411015.4:11]101/ وألقِّه على 
التفووع ركن دو و اا 
- اختر عرض الحقل )00 Authors.Bo0ks.8‏ في قائمة مركبة 
0101301 وألقه على النموذج ليعرض أسماء الكتب. 
- من نافذة الخصائص افتح الخاصية (sعمالم81هاه5)‏ وأزل الارتباط مع 
الخاصية ×].. ويمكنك بدلا منها أن تنشئ ارتباطا مع الخاصية 
211 حتى يتم حفظ القيمة التي يختارها المستخدم آليا في 
السك الك 
- توجه إلى الخاصية ©123350110 الخاصة بالقائمة المركبة» واضغط زر 
الإسدالء ومن القائمة اختر مصدر الربط AuthorsBindingSource‏ 
وأسدل عناصره الفرعية.. ستجد تحته اسم العلاقة بين جدول المؤلفين 
وجدول الكتب وهي 117015 _800125 _7”12.. اختر هذه العلاقة كمصدر 
للبيانات.. سيؤدي هذا إلى إضافة مصدر ربط جديد إلى البرنامج اسمه 
1151015501 وستوضع قيمته تلقائيا في 
الخاصية !DataSource‏ 
- توجه إلى الخاصية :زع ط1مرء1(31234» واضغط زر الإسدالء» ومن القائمة اختر 
الحقل ع800[1.. الآن تأكدنا أن القائمة المركبة ستعرض كتب المؤلف الحالى» 
لأننا ربطناها من خلال العلاقة بين المؤلفين والكتب. ۰ 
- من نافذة مصادر البيانات اسحب الحقل Authors. Books. ۴1e‏ وألقه على 
اللو عب جيه ر اهر اف ا الخ ان وا اة 
(ئDataBindin8)›‏ وتوجه إلى الخاصية ..1٠×)‏ اضغط زر الإسدال» واختر 


العنصر ۴KBooksAuthorsBindingSource‏ لربط مربع النص من 
خلال العلاقة. 

- يمكنك تكرار هذا مع أكثر من حقل من حقول جدول الكتب.. مثلاء لو سحبت 
الحقل ع1151_1(8طن2 وألقيته على النموذج» فستظهر أداة اختيار التاريخ 
والوقت م101 13167ء12361(26 لعرض قيمته.. وأيضا عليك أن تغير 
ارتباط الخاصية 57106 الخاصة بهذه الأداة» لتجعلها ترتبط من خلال المصدر 
5011 كما فعلنا مع مربع النص. 

الآن سيكون شكل النموذج كالتالي: 


Em م‎ 


اها كا دك | زم >4 of‏ 1 


Author: لحكيم]‎ ١ توفيق‎ 





Book: 


Publish Date: [a0 ذیسمبر‎ , 8 > 
Price: 000 





لو شغلت البرنامج» فسيمكنك التحرك عبر المؤلفين باستخدام شريط موجه الربط 
حيث ستظهر كتب المؤلف الحالي في القائمة المركبةء وكلما اخترت كتابا منهاء 
يظهر تاريخ نشره في أداة التاريخ» وسعره في مربع النص.. وبهذا نكون حصلنا 
على طريقة أخرى لعرض البيانات الرئيسية والتفاصيل وتفاصيل التفاصيل!.. 
صحيح أننا أجرينا بعض التعديلات اليدوية هذه المرة» ولكن صحيح أيضا أننا إلى 
الآن لم نكتب سطرا واحدا من الكود بأنفسنا!.. مرحىء ما أمتع الكسل! 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 





اللهم انصر ١‏ 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


٣ 


tov 


Ê‏ واجهة مزود مدير الت 


ICurrencyManaserProvider Interface 
تمتلك هذه الواجهة العنصرين التاليين:‎ 


7 فز مدير التسلسل :CurrencyManager‏ 
تعيد مدير التسلسل :861 010163:1/1212) التابع لمصدر البيانات الحالي.. 


#ا- معرفة مدير التسلسل التابع :GetRelatedCurrencyManager‏ 
أرسل إلى هذه الوسيلة اسم القائمة أو العمود الموجود في مصدر البيانات 
الحالي» لتعيد إليك مدير التسلسل CurrencyManager‏ الخاص به. . ويمكنك 
أن ترسل نصا فارغا "" أو ع2نط)70 إلى هذه الوسيلة» وفي هذه الحالة 
ستعيد إليك مدير التسلسل الخاص بمصدر البيانات ككل» وهو نفس مدير 
التسلسل الذي تحصل عليه من الخاصية .CurrencyManager‏ 


5-5 واجهة إلغاء إضافة الجديد 
ICancelAddNew Interface‏ 


تضيف هذه الواجهة إلى الفئة التي تمثلها القدرة على قبول العنصر الجديد المضاف 
أو التراجع عن إضافته» وهي تملك الوسيلتين التاليتين: 


> إلغاء الجديد 2061276 2©: 
أرسل إلى هذه الوسيلة رقم العنصر الذي أضفته سابقا إلى المجموعة» لتقوم 
بالتراجع عن إضافة (تقوم بحذفه). 


#أ> إنهاء الجديد :End New‏ 
أرسل إلى هذه الوسيلة رقم العنصر الذي أضفته سابقا إلى المجموعة» لتقوم 
بقبوله نهائيا.. هذا يعني أنك لا تستطيع استخدام الوسيلة :0222617161 بعد 
هذا للتراجع عن إضافة هذا العنصر. 


IRaiseltemChangedEvents Interface 
تمتلك هذه الو اجهة الخاضية الوحيدة الثالية:‎ 


57 ين إطلاق أحداث تغير العنصر :RaisesItemChangedEvents‏ 
تة هذه الخاضية عن[ اذا كانت الفقة التى تمكل هذه الواجية ستطلق 
الحدث لوع ه1150 إذا حدث تغير في أحد عناصر القائمة الداخلية 
الخاضة نها. 


2 فئة قائمة الربط عامة النوع BindingList(Of T) Class‏ 


هذه الفئة موجودة في النطاق 1ع5937:51610.00170116111/00» وهي ترت الفئة 
1 01 »؛»؛ وتمثل الواجهات IbindingList‏ و IList‏ 
و ICancelAddNew‏ و .IRaiseltemChangedEvents‏ 
وتعمل هذه الفئة كمجموعة عامة النوع م30]ء00116 6م1507 Generic‏ تدعم تقنية 
ربط البيانات عمنلما. 
ولحدث إنشاء هذه الفئة صيعتان: 

-١‏ الصيغة الأولى بدون معاملات. 

؟- والصيغة الثانية تستقبل قائمة عامة النوخ 11181)0619 لتنسخ عناصرها 

إلى قائمة الربط. 


وإضافة إلى ما ترثه من الفئة الأم» وما تمثله من خصائص ووسائل الواجهات 
المذكورة تمتلك هذه الفئة الوسيلتين الجديدتين التاليتين: 


37 تصفير الارتباطات وع112010)ءو122: كد 
تطلق الحدث 0عع 115:0 مع إرسال القيمة 61و26 إلى الخاصية 
.e.ListChangedType‏ 


7# تصفير العنصر ص ء)]) Rese‏ : 
تطلق الحدث 0ع115:0138 مع إرسال القيمة 1162100121860 إلى 
8 8 
الخاصية .e.ListChangedType‏ 


TListSource Interface 


فا الى اة ضر الخصراه على ا امن كاك 9 ل ر اة 
القائمة 11,156» مما يجعل من الممكن استخدام هذه الكائنات كمصدر للبيانات 
© عند ربطها بادوات عرض البيانات. 


وتمتلك هذه الواجهة العنصرين التاليين: 


فط تحتوي على مجموعة قوائم :Contains ListColIlection‏ 
تعيد 16 إذا كانت المجموعة الخاصة بالكائن الحالي تحتوي على قوائم 
داخلية. 


#> الحصول على القائمة )وز 6©)1: 
تعيد مجموعة تمثل واجهة القائمة ]1115» تحتوي على عناصر الكائن الحالي. 


2 فئة مصدر الربط BindingSource Class‏ 


هذه الفئة ترث الفئة 1ع 0مد20) لهذا ستجدها في صندوق الأدوات عزه71001 
تحت الشريط ه0 ويمكنك إضافتها إلى صينية مكونات النموذج. 
كماتمئل هف الفقفةالواجه ات [List‏ و BindingList View‏ 
و IcurrencyManagerProvider‏ و .I[CancelAddNew‏ 
وتحتوي هذه الفئة على قائمة داخلية ائ 17161031 تحتوي على عناصر مصدر 
البيانات» ليتم ربطها بالأدوات الموضوعة على النموذج» وبهذا تسهل هذه الفئة 
عملية الربط ع010م81 وتتيح لك التحكم فيها كما سنرى بعد قليل. 


ولحدث إنشاء هذه الفئة الصيغ التالية: 
-١‏ الصيغة الأولى بدون معاملات. 
؟- الصيغة الثانية لها معامل و من نوع الواجهة :ع10011810» وهو 
ينتقبل الاد الحاوية القى سيتامى الها مدر البياناث: امامل مع 
الأدوات الموضوعة عليها.. تذكر أن الأدوات الحاوية تشمل النموذج 
۴0m‏ واللوحة [عمرو7 ومربع التجميع عز0120110130... إلخ. 
۳- الصيغة الثالثة تستقبل الكائن Object‏ الذي يعمل كمصدر للبيانات» ونصا 
يمثل اسم عنصر البيانات. 
وإضافة إلى ماشاله من خصبائسن آل احيات انكر رة مك هذه القثة الخص اتن 
التالية: 


5 مصدر البيانات :54٤480u c6‏ 
تستقبل هذه الخاصية الكائن Object‏ الذي يعمل كمصدر البيانات.. هذا 
سيؤدي إلى ما ايلي 
اا سيحدد ا أنه من الو '1» ولن تقبل هذه القائمة 
أي بيانات لا يمكن تحويلها إلى هذا النوع. 
- إذا وضعت في هذه الخاصية القيمة عمز[]210: فستظل القائمة الداخلية 
غير محددة النوع» وستأخذ نوع أول عنصر تضيفه إليها باستخدام 
الوسيلة 4010. . لاحظ أن خطأ سيحدث في البرنامج إذا وضعت قيمة 
في الخاصية ۲ع اصع N‏ هاه بينما للخاصية 122125011106 القيمة 
.Nothing‏ 
- إذا كان الكائن بسيطا لا يحتوي على قائمة من العناصرء فإن القائمة 
الاكلية ميتكوق قر غة 


١ 


- إذا كان الكائن الذي وضعته في هذه الخاصية مصفوفة و4112 أو 
مجموعة 001161101)؛ فان عناصرها ستوضع في القائمة الداخلية. 
- إذا كان الكائن معقدا ويحتوي على قائمة من العناصر أو أكثر من 
قائمة؛» فيجل عليك ذكر اسم القائمة في الخاصية Data Member‏ 
(كاسم الجدول في مجموعة البيانات مثلا)» حيث ستوضع عناصر هذه 
القائمة في القائمة الداخلية. 
ويمكنك أن تضع في هذه الخاصية نوع أحد الكائنات بدلا من أن تضع الكائن 
نفسه. . فبدلا من أن تضع في هذه الخاصية مجموعة بيانات كالتالي: 
Bs.DataSource = Ds‏ 
يمكنك أن تضع نوع مجموعة البيانات كالتالي: 
Bs.DataSource = Ds.GetType( )‏ 
وإذا كانت لديك مجموعة بيانات محددة النوع 102125614 157060 اسمها 
95 فيمكنك استخدام نوعها كمصدر بيانات كالتالي: 
Bs.DataSource = GetType(BooksDs)‏ 
ولكنء فيم يفيدنا هذا؟ 
في بعض الأحيان تحتاج إلى تصميم بعض أدوات عرض البيانات في وقت 
التصميم (مثل جدول عرض البيانات «(DataGridView‏ وهذا معناه أنك 
ا إلى عرض | أعمدة لازن المرتيطة في * هذه ا لحن في رقت 
للبيانات» لهذا 980 هذه الخاصية بوضع نوع هذه الفئات فيهاء لتستنتج منه 
طريقة العرض المطلوبة. 
ويمكنك وضع قيمة هذه الخاصية بطريقة مرئية في وقت التصميم» وذلك 
باستخدام نافذة الخصائص» حيث سيعرض لك زر الإسدال شجرة العناصر 
المتاحة.. في هذه الشجرة ستجد عنصرين رئيسيين: 
:N008 -١‏ وهي القيمة الافتراضيةء وهي تجعل لهذه الخاصية القيمة 
.Nothing‏ 
؟"- :0ther Data Sources‏ وتحتها الاختیاران التالیان: 

أ. Data Sources‏ ectزPro:‏ ویوجد تحتها کل فئات مصادر البيانات 
المتاحة في المشروع كله.. ويؤدي اختيار أي فئة من هذه الفئات» 
إلى إنشاء نسخة جديدة منها وإضافتها إلى النموذج. 

ب. :۴0rm Data Sources‏ ويوجد تحتها كل الكائنات المعرفة في 
النموذج الحالي وتصلح كمصادر بيانات» مثل القوائم ووز 
ومجموعات البيانات 123425615 وغيرها. 

وفي الهامش السفلي للنافذة المسدلةء يوجد رابط اسمه: 
Add Project data Source‏ 


11 


عند الضغط عليه يتم تشغيل المعالج السحري لتهيئة مصادر البيانات 
(ata Source Configuration Wizard‏ ليمكنك إنشاء مصدر بيانات 
جديد وإضافته تحت الفرع .Project Data Sources‏ 


ا عنصر البيانات :Data Member‏ 
تستقبل اسم الخاصية أو اسم القائمة أو العمود الموجود في مصدر البيانات» 
والذي يتم أخذ البيانات منه. 

57 ف القائمة )1.15: 
تعيد نسخة من الواجهة 11156 تحتوي على القائمة الداخلية التي تحتوي على 





العناصر المرتبطة.. لاحظ أن نوع القائمة العائدة يتحدد تبعا لما يلي: 








قيمة الخاصية | قيمة الخاصية | القائمة العائدة من الخاصية 
List DataMember DataSource‏ 
Nothing‏ نص فارغ | مصفوفة قائمة A۲4111)‏ فارغة. 
Nothing‏ أي قيمة 0 7 1.51 سيحدث 
مصفوفة مصفوفة yھA]۲.‏ 
كاتن يمثل الواجهة الق ال دم ال اة 
IListSource.GetList IListSource‏ 
ا 0 نسخة من الواجهة :وذ ]عم1181001. 
الو 0 نسخة من الواجهة 156.]]. 
كائن بسيط من نس خةم ن الواجهة 
النوع 1 لا T(‏ 15])01اآع10لم181 بها عنصر 
يحتوي على قائمة واحد. 
گاقن يمكل الواجية اه 
HSS ICustomT ype‏ ا روكيد جيم 
Descriptor‏ عنصر واحد. 
كائن يمثل الواجهة مصفوفة قائمة 112161156 نسخت 
IEnumerable‏ إليها عناصر الكائن. 
نوع المصفوفات عنصر من نسخة فارغة من الفئنة 
Array Type‏ النوع 1آ .BindingList(Of T)‏ 
نوع كائن يمثل نسخة جيدة فارغة من نوع هذا 
الواجية الكائن. 


1T 















































قيمة الخاصية | قيمة الخاصية | القائمة العائدة من الخاصية 
List DataMember DataSource‏ 

IListSource 

أى الو احية 

كلدت طم 

الواجهة IList‏ النوع 1آ .BindingList(Of T)‏ 
يحتوي على قائمة .BindingList(Of T)‏ 

نوع كائن يمثل 

الواحية دقرا الكاف ةو سكت 

ICustomType‏ خطأ في البرنامج. 

Descriptor 











وخ کک :Position‏ 


57 زور الحالي :Current‏ 
تعيد كائنا 0ع[01) يحتوي على العنصر الحالي في القائمة الداخلية» وهو 
العنصر الموجود في الموضع المحدد في الخاصية 2051610. 


"ل الترتيب ۰0۲۲ 


تحدد طريقة ترتيب العناصر في القائمة» وهي تستقبل نصا يحتوي على اسم 
العمود المستخدم في الترتيب» متبوعا باتجاه الترتيب (4500/ أو .(DESC‏ 


ك5 




















57 فل هل الربط متوقف :IsBindingSuspended‏ 


تعيد عن[ إذا كان الربط متوقفا حاليا. 


3 إطلاق أحداث تغير القائمة :RaiseListChangedEvents‏ 


إذا جعلت قيمة هذه الخاصية 1:06 (وهي القيمة الافتراضية)؛ فسينطلق 
الحدث 1عع مدط15)0.آ.ع010850110م81 عندما يحدث تغيير في عناصر 
القائمة الداخلية. 


و تمتلك هذه الفقة الوسائل الثالية: 


اوا 


إلغاء التحرير :CancelE dit‏ 
ى اة تر تالكر الخال رق إن رحدل 


إنهاء التحرير :End Edi)‏ 
تنهي عملية تحرير العنصر الحالي؛ وتبقي على التغييرات التي حدثت له. 


التحرك إلى الأول :MoveFirst‏ 
تل ار عنصن في ا اغ هو اتر الهاني زو وام 


التحرك إلى الأخير ئو eءM0v::‏ 
تجعل آخر عنصر في القائمة الداخلية هو العنصر الحالي 
.(Position = Count -1)‏ 


التحرك إلى التالي :Move Nex)‏ 
لجل اضر الات فى ال ااا ة مو اتر الخال 
.(Position += 1)‏ 


التحرك إلى السابق :MovePrevious‏ 
تجعل العنصر السابق في القائمة الداخلية هو العنصر الحالي 
.(Position -= 1)‏ 


19> إزالة الحالي :RemoveCurrent‏ 
تزيل العنصر الحالي من القائمة الداخلية.. لاحظ أن خطأ سيحدث في الحالات 
التالية: 
- لو كانت للخاصية BindingSource.Allow Remove‏ القيمة .False‏ 
- لو كانت القائمة الداخلية للقراءة فقط /0119© 630 أو ثابتة الحجم 
.Fixed Size‏ 
- لو كان الموضع الحالي غير مقبول»ء سواء كان اصغر من صفر أو 
كان أكبر من أو يساوي عدد عناصر القائمة. 


7# تصفير العنصر الحالي :ResetCurrentI(em‏ 
تطلق الحدث 0عع1.15:0228 لتطلب من الأدوات التي تعرض العنصر 
الحالي أن تنعش القيم التي تعرضها. 


2# تصفير الارتباطات وع1812010)ءو1+2: 
تطلق الحدث 1,1560120 لتطلب من كل الأدوات المرتبطة بمصدر 
البيانات أن تنعش القيم التي تعرضهاء وهي تستقبل معاملا منطقياء إذا جعلت 
قيمته 116 فهذا معناه أن هناك تغييرا في مخطط مصدر البيانات نفسه 
(كحدوث تغيير في أعمدة الجدول)» وإذا جعلته 7196 فهذا معناه أن التغيير 
قد حدث في بعض عناصر القائمة الداخلية فقط. 
0 استدعاء هذه الوسيلة آليا عند ا قيمة الخاصية 1 أو 
ولكن.. لماذا نحتاج إلى a‏ الوسيلة ResetBindings‏ لإنعاش كل 
العناصرء بينما يكفينا إنعاش العنصر الحالي باستخدام الوسيلة 
21 . ألا تعرض الأدوات العنصر الحالي فقط؟ 
والإجابة هي أن بعض الأدوات تعرض أكثر من عنصر في نفس الوقت 
(كالقائمة 115618301 وجدول عرض البيانات 10343011017161)» بينما بعض 
الأدوات تعرض السجل الحالي فقط (مثل مربع النص واللافتة).. لهذا إذا 
0 عدد من العناصر وكنت تعرض البيانات في قائمة أو جدول 
ض» فعليك باستدعاء الوسيلة <«ResetBindings‏ أما إذا كنت تستخدم 
88 رط ا یر النص واللافتة وحدث تغير في العنصر الحالي» 
فاستخدم الوسيلة ]٥إ ..R eeu‏ أما إذا كان التغير في عنصر غير 
العنصر الحاليء فلا تحتاج إلى إنعاش الأدوات البسيظة» لأنها ستتعش تفسها 
تلقائيا عند الانتقال إلى العنصر الذي تغير 
2# تصفير العنصر «ررء)12056)1: 


1 


تطلق الحدث 0عع1.15]013 لتطلب من الأدوات التي تعرض العنصر الذي 
تغير في السجل الحالي بأن تنعش القيمة التي تعرضها.. وتستقبل هذه الوسيلة 
ويتم استدعاء هذه الوسيلة آليا كلما حدث تغيير لأحد عناصر القائمة الداخلية؛ 
لكن بإمكانك استدعاؤها بنفسك أيضا. 


إيقاف الربط :Suspend Binding‏ 
توقف ربط المصدر الحالي بالأدوات مؤقتا. 


مواصلة الربط :ResumeBinding‏ 
تعيد ربط الأدوات بالمصدر الحالي. 


وإضافة إلى ما تمثله من أحداث الواجهات التي تمثلهاء تمتلك هذه الفئة الأحداث 
التاليةء وكلها مالوف لنا لهذا لن نكرر شرحها هنا: 


د ê ê‏ وه يد وذ 


# 


الربط اكتمل BindingCom plete‏ 
الحالي تغير CurrentChanged‏ 

العنصر الحالي تغير CurrentIteChanged‏ 
عنصر البيانات تغير DataMemberChanged‏ 
مصدر البيانات تغير DataSourceChanged‏ 
الموضع تغير PositionChanged‏ 

خطأ البيانات DataError‏ 
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42 فئة مساعد ربط القوائم ListBinding Helper Class‏ 


تحتوي هذه الفئة على بعض الوسائل المشتركة 1741615005 553160» التي 
تستخدمها الفئة ع11 8101850 في التعامل مع مصدر البيانات.. وهذه الوسائل 
هي: 


ك 1# معرفة القائمة tءز[)ء6:‏ 
تستقبل الكائن الذي يعمل كمصدر بيانات» وتعيد قائمة البيانات التي يحتويهاء 
والتي يمكن الارتباط بها إن وجدت» فإن لم توجدء فإن هذه الوسيلة تعيد كائن 
وتوجد صيغة أخرى لهذه الوسيلة» لها معامل ثان» يستقبل اسم الخاصية التي 
الخاصية مها 1 


© 19> معرفة اسم القائمة :GetListName‏ 
تعيد اسم القائمة إن وجدت» أو اسم نوع مصدر البيانات» ولها معاملان: 
-. الكلان الذي يعمل كمصدر للبيانات: 
- مصفوفة من واصفات الخصائص 270611571065601301401» التي تحدد 
القائمة المر اد معورقة اسمها. 


كت معرفة نوع عناصر القائمة 6م18 :GetListI(e ıı‏ 
هذه الوسيلة مماثلة في صيغتيها للوسيلة السابقةء إلا أنها تعيد كائن النوع 
ممرا» الذي يمثل نوع عناصر القائمة. 


© 19> معرفة خصائص عناصر القائمة :GetListItem Properties‏ 
تعيد مجموعة واصفات الخصائص «PropertyDescriptorCo1lection‏ 
القن لصيف خسان ضر الات :وتيت اا ا مات 
- الكائن الذي يعمل كمصدر للبيانات. 
- مصفوفة من واصفات الخصائص 217061157106501370601»: التي تحدد 
القائمة المز اد التعامل منعها: 
وتوجد صيغتان أخريان لهذه الوسيلة» إحداهما تستقبل المعامل الأول فقط 
والأخرى تستقبل المعاملين الأول والثالث فقط. 


42 فئة موجه الربط BindingNavigator Class‏ 


1A 


هذه الفئة ترث فئة رف الأدوات Class‏ م1001511» لهذا فهي تعمل كرف أدوات 
يعرض مجموعة من الأزرارء التي تتيح للمستخدم التحرك عبر سجلات مصدر 
البيانات وحذف السجل الحالى أو إضافة سجل جديد» كل هذا بدون أن تكتب أنت 
حرفا من الكود! ۰ 

ويبدو رف الأدوات الذي يعرضه موجه الربط في وقت التصميم كما في الصورة: 


n 0 of {O0} > كا عه اط‎ G3 


لاحظ أن آخر زر على الشريط يتيح لك إضافة أزرار وأدوات جديدة إلى الشريط 
بنفس الطريقة التي تعلمناها في كتاب برمجة الويندوز.. هذا معناه أنك تستطيع 
استغلال مساحة الشريط لإضافة أزرار وقوائم ومربعات نصوص ولافتات تؤدي 
أية وظائف أخرى خاصة بك (كالقص واللصق وعرض حالة البرنامج وغير هذا)» 
وبهذا لا تحتاج إلى إضافة رف أدوات آخر خاص بك. 

والصورة التالية تريك كيف يبدو موجه الربط عند تشغيل المشروع 2135182601 
المرفق بأمثلة هذا الكتاب: 


ا×اھا۔ 


o 15 

علي أحمد باكثير | Author:‏ 

Phone: EEE 

| ووائي وصسرحي يمني راحل|ً About:‏ 


× +| |[ 68ه 4 4 14 


مرة أخرى أذكرك: لو أضفت سجلا جديد بضغط زر الإضافة الموجود على شريط 
موجه الربط أو حذفت السجل الحالي بضغط زر الحذف» أو غيرت قيمة أي حقل 
في السجل الحالي بتغيير قيمة أحد مربعات النصء فإن هذه التغييرات ستؤثر فقط 
على مجموعة البيانات 56ا04 لكن تظل مهمة تحديث قاعدة البيانات متروكة 
لك.. وإذا كنت لا ترغب أن يعبث المستخدم بقيم بعض الحقول» فاجعل مربعات 
النصوص المناظرة لها للقراءة فقطء أو اربط هذه الحقول بلافتات منذ البداية.. مع 
ملاحظة أن تغيير المستخدم لقيمة المعرف 17 لن تؤثر في شيءء لأن هذا الحقل 
مولد آلياء ومصدر البيانات لا يستطيع تغييره. 









۹ 


ولو لم تكن ترغب في أن يحذف المستخدم السجلات أو يضيف سجلات جديدة 
فيمكنك إزالة زو الحذف أو زر الإضبافة من قوق الشتريط فى وقت التصميم: أو 
يمكنك تعطيلهماء وسترى كيف نفعل هذا بعد قليل ونحن نتعرف على خصائص 
موجه الربط. 
ولحدث إنشاء الفئة :101هع1251اع 210010 الصيغ التالية: 
-١‏ الصيغة الأولى بدون معاملات. 
- الصيغة الثاني تستقبل كائن مصدر ريط «BindingSource‏ الذي 
2 يد 51 ذا حملت ووو فلن ركن وغد 
الربط أزرار التحكم القياسية (أزرار الانتقال وزر الحذف وزر الإضافة). 
-٤‏ الصيغة الرابعة تستقبل كائنامن نوع الواجهة إع1Contain‏ 
(مثل النموذج)» ليتم عرض شريط موجه الربط عليه. 
وإضافة إلى ماترثه من خصائص الفئة «ToolStrip‏ تمتلك الفئة 
Binding Navigator‏ الخصائص التالية: 


و- مصدر الربط :BindingSource‏ 
تقرا أو تغير كائن مصدر الربط 8100128501106 الذي يستخدمه موجه 
الربط للتحكم في السجلات. 


3 عنصر إضافة جديد :Add New1tem‏ 

تقرأ أو تغير عنصر رف الأدوات ٥٤آمذ٣† ٠٠018‏ المستخدم لإضافة سجل 
جديد إلى مصدر البيانات.. وفي الوضع الافتراضي يكون هذا العنصر من 
النوع 131101م10015111'.. ويكون زر الإضافة معطلا على شريط موجه 
الربطء إذا كانت للخاصية BindingSource.A1low New‏ القيمة .False‏ 
لاحظ أنك قد تجد زر الإضافة معطلا في بعض البرامج.. إذا حدثت معك هذه 
المشكلةء فيمكنك وضع القيمة ع1ط)710 في هذه الخاصية من الكودء أو 
اختيار | القيمة (None)‏ فيو القائمة المنسدلة في اة الخضاتص. هذا چ 
گر مرتين ا وكتابة ا الوحيد التالى في حدث طبغطه»” 

AuthorsBindingNavigator.BindingSource.AddNew( ) 


وجا عنصر الحذف :Dele) e)‏ 
تقرأ أو تغير عنصر رف الأدوات ToolStripItem‏ المستخدم لحذف السجل 
الحالي من مهبو الرانات وف ارك الافاراضئ كرق هذا الف مه 
النوع 1811]0م10015111'.. ويكون زر الحذف معطلا على شريط موجه 
الربطء إذا كانت للخاصية BindingSource.Allow Remove‏ القيمة ع1"215. 
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وإذا وجدت زر الحذف معطلا في بعض الحالات» فضع القيمة Nothing‏ في 
هذه الخاصية من الكود. أو (مصN0)‏ من القائمة المنسدلة في نافذة 
الخصائصء ثم انقر مرتين بالفأرة فوق زر الحذف الموجود على شريط موجه 
الربط » واكتب السطر الوحيد التالي في حدث ضغطه: 

AuthorsBindingNavigator.BindingSource.RemoveCurrent( ) 


کک عنصر التحرك إلى الأول :MoveFirstI(em‏ 
تقرأ أو تغير عنصر رف الأدوات 1مهغ1م100151 المستخدم للانتقال إلى 
أول سجل في مصدر البيانات.. وفي الوضع الافتراضي يكون هذا العنصر 
من النوع .ToolStripButton‏ 


وخ عنصر التحرك إلى الأخير ء)])ء14 ء0۷ :M‏ 
تقرا أو تغير عنصر رف الادوات ToolStripItem‏ المستخدم للانتقال إلى 
من النوع .ToolStripButton‏ 


وخ عنصر التحرك إلى التالي :MoveNextI(em‏ 
تقرا او تغير حتصير رف ToolStripItem‏ المستة 0-0 ككل إلى 
زر رف الأدوات .ToolStripButton‏ 


وا عنصر التحرك إلى السابق :MovePreviousItem‏ 
تقرأ أو تغير عنصر رف الأدوات ToolStripItem‏ المستخدم للانتقال إلى 
الل الاق قي مصددن البياات.. وفي الوطبع الافتراطي يكون هذا 
العنصر من النوع .ToolStripButton‏ 


۷١ 


وع عنصر الموضع ددرء20511021)6: 
تقرأ أو تغير عنصر رف الأدوات جمع16م100151 المستخدم لعرض رقم 
السجل المعروض حاليا.. وفي الوضع الافتراضي يستخدم مربع نص رف 
الأدوات ع:12130م100151' لهذا الغرضء وذلك للسماح للمستخدم بكتابة 
رقم السجل الذي يريده وضغط زر الإدخال ع2 للانتقال إليه مباشرة.. 
.BindingSource.Position‏ 


3 عنصر العد :CountI(em‏ 
تقرأ أو تغير عنصر رف الأدوات 1مهع16م1001511 المستخدم لعرض العدد 
الكلي للسجلات في مصدر البيانات.. وفي الوضع الافتراضي تستخدم لافتة 
رف أدوات 1ع26.آ1م700153 لهذا الغرض» وهي تعرض قيمة الخاصية 
.BindingSource.Count‏ 


ال تنسيق عنصر العد :CountItemFormat‏ 
تستقبل نصا يمثل الصيغة التي سيستخدمها عنصر العد nع)آارuهC‏ لعرض 
عدد السجلات.. وفي الوضع الافتراضي تكون قيمة هذه الخاصية " 01 
إ0".. وفي المشاريع العربية عليك تغييرها إلى صيغة مناسبة» مثل "من 
إ٠"‏ ليبدو الشريط كما في الصورة: 


Form OOS. ا×ادا۔‎ 





١‏ ,0 من ۸ ١4 ٩‏ © ي 





وتمتلك الفئة 810108135182 الوسائل التالية: 


VY 


#> إضافة العناصر القياسية :AddStandard1(ems‏ 
تضيف أزرار الانتقال والحذف والإضافة ومربع نص الموضع ولافتة عدد 
السجلات إلى شريط موجه الربط.. هذا مفيد إذا أردت إنشاء موجه ربط من 
الكود وليس في وقت لتصميم.. وفي حالة وجود العناصر القياسية بالفعل على 
الشريط فان هذه الوسيلة لا تحذفهاء» بل تضيف نسخة أخرى منهاء لكنها لا 
تصير هى العتاضر الفعالة 


©ا- إجازة :Validate‏ 
تجعل النموذج يفحص قيم الأدوات الموجودة عليه وتعيد ع111' إذا كانت 


كما تمتلك الفئة :810181735182101 الحدث التالي: 
إنعاش العناصر :RefreshItems‏ 


ينطلق إذا حدثت تغيرات في مصدر البيانات» تستدعي تحديث أزرار ولافتات 
موجه الربط. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


VT 


-ذ١ه‎ 


جدول عرض البيانات 
DataGrid View‏ 


توجد الأداة DataGridView‏ تحت الشريط 1348 في صندوق الأدوات 
×0 ط001 ]› وهي تصلح لعرض جداول قواعد البيانات» وتتيح لك تنسيق البيانات 
المعروضة بالشكل الذي يناسبك» كما تتيح للمستخدم إضافة السجلات وحذفهاء 
وتغيير قيم خاناتهاء حيث تحفظ هذه التعديلات مباشرة في الجدول الأصلي في 
مجموعة البيانات من خلال آلية الربط» ويمكنك بعد هذا إجراء عملية تحديث 
Update‏ لإرسال هذه التغييرات إلى قاعدة البيانات. 


ملحوظة: 

الأداة 1038011097167 هي تطوير لأداة قديمة اسمها 1034301110 وهي ما 
زالت متاحة للاستخدام لكنها لا تظهر في شريط الأدوات إلا إذا قمت أنت 
بإضافتها إليه بالطريقة المألوفة. . وننصح باستخدام الأداة DataGridView‏ 
لأنها تملك قدرات أكثر بكثير» وإن كانت الأداة 17220110 تتفرد بالقليل من 
الميزات؛ لهذا سنتعرف عليها في الفصل الثالي. 








ولربط جدول العرض بأحد جداول قاعدة البيانات» يمكنك استخدام الخاصيتنين 

DataSource‏ 1231233161161 بإحدى الطريقتين التاليتين: 
-١‏ أن تضع مجموعة البيانات في الخاصية 16 * 99 وتضع اسم 

الجدول في الخاصية 1ع21ء 123121 كالتالي: 
DataGridView1.DataSource = DsBooks‏ 
DataGrid View1.DataMember = "Authors"‏ 
- أن تضع الجدول مباشرة في الخاصية 1722501106 كالتالي: 
DataGridView1.DataSource = DsBooks.Tables('"Authors")‏ 
في كلتا الحالتين سيظهر جدول العرض كما في الصورة: 


VE 














كما تلاحظ في الصورة»ء يتكون جدول عرض البيانات مما يلي: 

- أعمدة وصصuاه٤»‏ ولكل عمود منها رأس إملهم][[» وهو خانة ثابتة من 
خانات الجدول تظهر أعلى العمود وتعرض عنوان العمودء لهذا سنسمي رأس 
العمود أحيانا بخانة العنوان. 

- صفوف 21790375 ولكل منها هامش عند الضغط عليه يتم تحديد الصف.. هذا 
الهامش يسمى رأس الصف» أو خانة عنوان الصف› وهويعرض أيقونة 
التحرير عند الكتابة في أي خانة في الصف. ويعرض أيقونة الخطأ عند وجود 
قيم خاطئة في الصفء كما يمكنك أن تكتب فيه نصا كعنوان للصف.. لاحظ أن 
الصف الأخير (الذي تسبقه النجمة *) هو صف جديد +1201 سء عندما 
يكتب فيه المستخدم تتم إضافته إلى الجدول» ويظهر صف جديد بدلا منه. 

- خلايا و0611: وهي خانات الجدول» ويمكنك ضغطها بالفأرة لبدء تحريرهاء 
وعندما تكون الخانة في وضع التحريرء يظهر فيها مربع نص للكتابة فيه.. 
ويمكن إنهاء التحرير بضغط :861 أو إلغائه بضغط ٥و‏ لتعود القيمة 
الأصلية للخانة.. ولا يتم قبول التغييرات التي حدثت في خانات أحد الصفوف 
إلا إذا ضغط المستخدم ۲٥ہ‏ + CR‏ أو انتقل إلى صف آخر. 

- خلفية جدول العرضء وهى المنطقة الخالية التى لا تظهر فيها الخانات. 

ويمكنك ربط جدول العرض بمصادر بيانات أخرى غير جداول البيانات.. 

والمشروع :810000110101123 يريك كيف يمكن ربط جدول العرض بمصفوفة 

تحتوي على كائنات من نوع الفئة 561061» وبسطر واحد من الكود: 

Grd.DataSource = Std 

كل ما فعلناه هو استخدام المصفوفة كمصدر للبيانات» ليقوم جدول العرض تلقائيا 

بإنشاء أعمدة بأسماء خصائص الفئة ٤ل‏ ن]؟» ووضع قيم المصفوفة فيها.. منتهى 

البساطة والروعة! 

لكن لا تدع هذه البساطة تخدعك» فجدول العرض أداة ضخمة»ء وهناك عدد كبير 

من الفئات 01355) لتمثيل مكوناتهاء والتي ستجدها مشروحة بالتفصيل في الملحق 

رقم :١‏ فئات جدول العرضء فارجع إليه كلما مرت عليه إحدى هذه الفئات هنا. 


{Vo 








42 فئة جدول عرض البيانات DataGrid View Class‏ 


هذه الفئة ترث فئة الأداة الأم 1255© 00101» وهي تعرض وتتحكم في الأعمدة 
والضفوف والخانات التى تعرفنا عليها. 

ونوا لن هذه الكذاة تملك عدا هائلا من الخضبائضن والوسائل» فمتشيميها إلى 
مجموعات حسب الوظيفة ليسهل علينا فهمها. 


التعامل مع أعمدة جدول العرض: 
يقدم لك جدول العرض الخصائص التاليةء للتعامل مع الأعمدة: 


59 هزر الأعمدة :Columns‏ 
تعيد مجموعة أعمدة جدول العرض 11 1107 
التي تحتوى على كائنات الأعمدة DataGridViewColumn Objects‏ 


الموجودة في جدول العرض. 

ويمكنك إضافة الأعمدة إلى هذه المجموعة في وقت التصميم باستخدام نافذة 
الخصائصء وذلك بضغط زر الانتقال الموجود في خانة قيمة هذه الخاصية» 
حيث ستظهر لك النافذة الموضحة في الصورة: 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


۷٦ 


selected Columns: Unbound Column Properties 


















SortMlode Notsortable 
El Data 
DataPropertyame (none) 
DataSource (none) 
DisplayMember (none) 
سم‎ Collection) 
YalueMember {none} 
El Design 
(Name) ColCity 
Items 


The collection of objects used as selections in the 


Add... | Remove | combo boxes. 
EE Cancel 


2 


في هذه النافذة تظهر أسماء الأعمدة في القائمة اليسرىء بينما تظهر خصائص 
العمود المحدد في الجزء الأيمن.. على سبيل المثال» تريك الصورة خصائص 
العفو د المسسى "النديكة" وهو كد بعركن قائفة بسيدلة. : ويبكتك ا اة 
العناصر إلى هذه القائمة بضغط زر الانتقال الموجود فى خانة الخاصية 
315 في قسم الخصائص» حيث ستظهر لك نافذة تتيح لك إضافة عناصر 
إلى المجموعة. 

ويمكنك حذف أي عمود من القائمة بتحديده وضغط الزر 1867200176.. 
ويمكنك إضافة عمود جديد بضغط الزر 4400» حيث ستظهر لك نافذة فرعية 
تتيح لك إدخال بيانات العمود» كما هو موضح في الصورة: 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 





VY 








f Databound 6 


Columns in the DataSource 


© Unbound colurnn 


Marne: [ColName 
Type: [DatacridviewTextEoxColumn ف‎ 1 
Header text: الاسم‎ 


IV visible I Readonly f Frozen 


Add | Cancel | 





هذه النافذة تتيح لك اختيارين: 


-١ 


إنشاء عمود مرتبط بمصدر بيانات :Data-bound Column‏ 

هذا الاختيار يكون متاحا فقط إذا كان جدول العرض مرتبطا بمصدر 

البيانات من خلال الخاصية ع12(3350110.. في هذه الحالة ستعرض 

القائمة العلوية أسماء الأعمدة المتاحة فى مصدر البيانات» وعليك 

تحديد واحد منها لربط العمود الجديد به.. لاحظ أنك لا تستطيع عرض 

أعمدة مرتبطة بأكثر من جدول بيانات في نفس جدول العرض. 

إنشاء عمود غير مرتبط بمصدر بيانات :Unbound Column‏ 

هذا الاختيار متاح دائماء ولو فعّلته فيجب عليك كتابة تفاصيل العمود 

کما یلی: 

- كتابة الاسم البرمجي للعمود في الخانة 6::ة/2.. لاحظ أن كل 

عمود تنشئه في هذه النافذة» يتم تعريف متغير بنفس اسمه على 
مستوى النموذج» لتستطيع استخدامه مباشرة في التعامل مع 
السود مما يجعل الكود مختصيرا.. لهذا عليك اختياز انه 
مناسب للعمود يدل على وظيفته» مع وضع بادئة مميزة له 
(ولتكن 001) كي لا يتعارض مع أي متغيرات أخرى معرفة 
في البرتامج.. يمكنك مثلا أن تسمي عمود المولفين 
175 وعمود الكتب 001800[125.. وهكذا. 


VA 


- اختيار نوع العمود من القائمة المنسدلة 6م/159.. والعمود النصي 
20110 ]33011017167162 هو النوع الافتراضي» 
ويمكنك اختيار أي نوع آخر كعمود القوائم المركبة 
.DataGridViewCombBoxColunn‏ 
- كتابة عنوان العمود (الذي سيعرضه الجدول)» في الخانة 
.Header Text‏ 
من مربع الاختيار ©1715101. 
- إذا كان العمود للقراءة فقط ولا يمكن للمستخدم تحرير خاناته» 
فضع علامة الاختيار في مربع الاختيار 015 adء‌R.‏ 
- إذا كان العمود ثابتاء ولا يمكن للمستخدم تغيير عرضه بالفأرةء 
فضع علامة الاختيار في مربع الاختيار ع11027آ. 
وبعد أن تنتهي من إدخال تفاصيل العمود» اضغط الزر ۸4 لإضافته إلى 
مجمو عة الأعمدة.. لاحظ أن هذا لن يغلق هذه النافذة» بل سيعيد خاناتها إلى 
قيمها الافتراضية ليتيح لك إنشاء عمود جديد مباشرة. 
لاحظ أنك تستطيع إنشاء أعمدة مرتبطة واعدة غير مرتبطة في نفس الجدول.. 
لكن هذا سيعقد الأمور عليك» لأن جدول العرض يمحو قيم الأعمدة غير 
المرتبطة عندمايقوم بتحديث قيم الأعمدة المرتبطةة» 
مثلما يحدث عند ضغط رأس العمود لترتيب الصفوف!.. لهذا بذلنا بعض 
الجهد في المشروع 011560501031256 للمحافظة على قيم العمود غير 
المرتبط الذي يعرض أسماء المواد الدراسة في نافذة درجات الطالب. 
بعد إن تنتهي من إنشاء كل الأعمدة التي تريدهاء اضغط Cancel‏ لإغلاق 
هذه النافذة والعودة إلى النافذة السابقة» حيث ستجد الأعمدة التي أنشأتها 
موجودة في قائمة الأعمدةء ومن ثم يمكنك تحديد كل منها وتغيير خصائصه 
كما تريد.. مثلاء إذا أردت توسيط النص في خانات العمود»ء فحدد هذا العمود 
في القن الأيسرء ومن القسم الأيمن اختر الخاصية ع126181011061156/1» 
واضغط الزر الموجود في خانة قيمتهاء لعرض نافذة باني طراز الخانة 
Builder‏ eاe15ty»‏ التي تتيح لك تغيير خصائص شكل الخانة بصورة 
مرئية.. كما في الصورة: 


۹ 


CellStyle Builder EPS) 


El Appearance 
BackColor ] [ silver 
(none) 
ForeColor 2 
selectionBackColor 
selectionForeColar 

El Beha¥ior 


Format 
El Data 


NullYalue 
El Layout 

Alignment 
Padding 

Wraplode 





Preview 
This preview shows properties from inherited CellStyles (Table, Column, Row} 
Normal: Selected: 


OK | Cancel | 





هذه النافذة تتيح لك وضع قيم كائن طراز الخانة CellStyle‏ بشكل مرئي 
وسهل» وهي متاحة للاستخدام أيضا في نافذة الخصائص مع كل الخصائص 
التي تتعامل مع طراز الخانةء مثل الخاصية »106181110611516716.. ويمكنك 
استخدام هذه النافذة كما يلي: 
5 اضغط رق الإسدال في خانات خصائص الألوان» لعرض مربع اختيار 
اللون. 
- اضغطزر الإسدال في خنتي المح ذاة Alignment‏ 
و WrapMode‏ لاختيار القيمة المناسبة من القائمة المنسدلة. 
- اضغط زر الانتقال في خانة الخط ‘Font‏ لعرض مربع اختيار الخط. 
- اضغط زر الانتقال في خانة التنسيق 2034ه*1» لعرض مربع إنشاء 
نص التنسيق» وهو كما في الصورة: 











Format String Dialog 2× 


]- Format 
Specify the format for date and time values, 


Format type: Sample 
| 07 ص‎ + Tho ++ سب نقبزء‎ ١ 


Jo Formatting 


Null value: | 





لس 








OK | Cancel | 


في هذه النافذة يمكنك اختيار نوع التنسيق من القائمة اليسرى» حيث 
ستظهر في الجانب الأيمن بعض الاختيارات التي تتيح لك إنشاء صيغة 
ه مربع نص القيمة المنعدمة 172106 71011 لتكتب فيه القيمة التي 
ستستخدم عندما يترك المستخدم الخانة فارغة. 
مربع رقمي 1 (0W‏ مل ۲۶ں يتيح لك تحديد عدد الخانات 
العشرية في صيغ الأرقام والعملة والنسب المئوية. 
ما يعنيا هنا هو الخاصية 41150774 التي تتيح لك اختيار محاذاة النص في 
خانات العمود.. ولتوسيط النصء اختر القيمة ع1مع72111016)0 من القائمة 
المنسدلة» واضغط 0 للعودة إلى نافذة الأعمدة. 
وبعد أن تنتهي من إنشاء كل الأعمدة وضبط خصائصهاء اضغط 0 لإغلاق 
النافذة.. ستجد الأعمدة التي أنشأتها قد ظهرت في جدول العرض في وقت 
الصف 


A! 














لق عدد الأعمدة ‘ColumnCount‏ 

تقرأ أو تغير عدد الأعمدة الموجودة في جدول العرض. . لاحظ أن وضع الرقم 
٠‏ في هذه الخاصية سيحذف كل أعمدة الجدول» وإذا جعلت لها قيمة أقل من 
عدد الأعمدة الحالية فسيتم حذف بعضص الأعمدة من نهاية مجمو عه 3 الأعمدة 
5 أ أما إذا وضعت فيها عددا أكبر من عدد الأعمدة الحالي» فسيتم 
إنشاء أعمدة نصية وإضافتها إلى نهاية مجموعة الأعمدة» وستكون هذه 
الأعمدة بدون عناوين.. وتسبب هذه الخاصية خطأ إذا حاولت استخدامها مع 
جدول عرض مرتبط بمصدر بيانات. 


وخ السماح للمستخدم بترتيب الأعمدة :AllowUserToOrderColumns‏ 
إذا جعلت قيمة هذه الخاصية ع11» فسيستطيع المستخدم سحب الأعمدة من 
مواضعها لإعادة ترتيبها.. والقيمة الافتراضية لهذه الخاصية مواه۴. 


وخ السماح للمستخدم بتغيير حجم الأعمدة :AllowUserToResizeColumns‏ 
إذا جعلت قيمة هذه الخاصية عن[]” (وهي القيمة الافتراضية)؛ فسيستطيع 


المستخدم سحب الحافة اليمنى للعمود بالفأرة لتكبير عرضه أو تصغيره. 


وخ إنتاج الأعمدة تلقائيا :AutoGenerateColumıs‏ 
إذا جعلت قيمة هذه الخاصية ©11[]” (وهي القيمة الافتراض ضية)» ذ فسيتم إنشاء 
الأعمدة تلقائيا عند ربط جدول العرض بمصدر البيانات. 


وخا طريقة التحجيم التلقائي للأعمدة :AutoSizeColumnsMode‏ 
توضح كيف يتم تغيير عرض الأعمدة تلقائيا تبعا لمحتوياتهاء وهي تأخذ إحدى 
قيم المرقم »Data Gri ViewAutoSizeColumnsMode‏ وهو يملك نفس 
قيم المرقم t4 Gri View AutoSizeColumnMode‏ الذي تعرفنا عليه 
سابقاء ما عدا القيمة )ع821015. 


اا رءوس الأعمدة مرئية -ColumnHeadersVisib]e‏ 
إذا جعلت قيمة هذه الخاصية ع1815» فلن يتم عرض الصف الذي يحتوي على 
رؤوس الأعمدة.. والقيمة الافتراضية لهذه الخاصية هي 15106. 


وخ ارتفاع رءوس الأعمدة :ColumnHeadersHeight‏ 
تقرأ أو تغير ارتفاع الصف الذي يحوي رءوس الأعمدة. 


بذك 


وخ طريقة تغيير ارتفاع رءوس الأعمدة :ColumnHeadersHeightSize Mode‏ 
تحدد كيفية تغير ارتفاع الصف الذي يحتوي على رءوس الأعمدة» وهي تأخذ 
إحدى قيم المرقم :DataGridViewColumnHeadersHeightSize Mode‏ 


8 | السماح للمستخدم بتغيير ارتفاع رءوس الأعمدة. 
8 | عدم السماح للمستخدم بتغيير ارتفاع رءوس الأعمدة. 
AutoSize‏ تغيير ارتفاع رءوس الأعمدة تلقائيا ليناسب عناوينها. 








ق عرض الجبزء المختفي من ول عمود ظقاهر 
:FirstDisplayedScrollingColumnHidden Width‏ 
تعيد عرض الجزء المختفي من أول عمود ظاهر على الشاشة حاليا. 


وخ رقم أول عمود ظاهر :FirstDisplayedScrollingColumnIndex‏ 
تعيد رقم أول عمود ظاهر على الشاشة حاليا.. ويمكنك أيضا تغيير قيمة هذه 
ظاهر.. والمثال التالي ينزلق إلى العمود العاشر إن لم يكن ظاهرا على 
الشاشة: 
Dgv.FirstDisplayedScrollingColumnIndex = 9‏ 
ويؤدي استخدام رقم عمود غير موجود إلى حدوث خطأ في البرنامج.. على 
سبيل المثال» ستسبب الجملة السابقة خطأ إذا كان عدد الأعمدة أقل من .٠١‏ 


7 ف الأعمدة المحددة :Selected Columns‏ 
تعيد مجموعة أعمدة «DataGridViewSelectedColumnCollection‏ 
وهي مجموعة ترث الفئة 835600011614102 وتمثل واجهة القائمة 11.156» 
وتحتوي على الأعمدة المحددة حاليا في الجدول. 


57 ف عمود الترتيب :SortedColumn‏ 
تعيد كائن العمود مدص آه٣wع‏ ۷1 6۲14هه( الذي تم ترتيب صفوف جدول 
العرض تبعا لترتيب خاناته.. وتعيد هذه الخاصية عمنطه. إذا لم يكن جدول 
العرض مرتبا. 


تنك 

















وخ طراز حواف رؤوس الأعمدة :ColumnHeadersBorderSty]e‏ 
تحدد شكل إطار خانات العناوين» وهي تأخذ إحدى قيم المرقم 
hata GridViewHeaderBorderStyle‏ التالية: 


Nore‏ | لا توجد إطارات. 

عاعمزه | إطار من خط مفرد. 
4 إإطار بارز. 
١ Sunken‏ إطار غائر. 
Custon‏ إطار مخصص.. هذه القيمة للقراءة فقطء ولا يمكنك وضعها 
بنفسك» وإنما تتغير تلقائيا عند تغيير قيمة الخاصية 
.AdvancedColumnHeadersBorderStyle‏ 











57 الطراز الافتراضي لخانات رءوس الأعمدة 
:ColumnHeadersDefaultCellStyle‏ 
تقرأ أو تغير كائن طراز الخانة eإر†؟611‏ 123806110171650 المستخدم مع 
خانات رؤوس الأعمدة.. ويمكنك تغيير هذا الطراز بشكل مرئى من نافذة 
الخصائصء وذلك بضغط زر الانتقال الموجود في خانة قيمة هذه الخاصية 
لعرض نافذة باني طراز الخانة .CellStyle Builder‏ 


2 بت الغ رز المتط سو لحاف ةرووس الأعمدة 
:AdvancedColumnHeadersBorderStyle‏ 
تعيد كائن الطراز المتطور DataGridViewAdvancedBorderStyle‏ 
الذي يتعامل مع إطارات خانات عناوين الأعمدة. 


7 ف طراز الحافة المض بوط للخانة العلوية اليسرى 
:AdjustedTopLeftHeaderBorderStyle‏ 
تعيد كائن الطراز المتطور DataGridViewAdvancedBorderStyle‏ 
الذي يتعامل مع إطارات الخانة العلوية اليسرى في الجدول. 


3 تفعيل الطرازات الشكلية للخانات الرئيسية :EnableHeadersVisua1Sty1es‏ 
إذا حت قبية هذه الخاضبية 6نم 1؛ فس استخدام طراز الخواف وطراق 
الخانات مع رءوس الأعمدة ورءوس الصفوف.. لاحظ أن هذا سيمنع تأثير 
فيص ات اراد دی ااا ا 
ColumnHeadersDefaultCellStyles‏ أو 
»RowHeadersDefaultCelStyles‏ فمثلا: لو غيرت لون خلفية الخانات 


At 




















الرئيسية في تلك الخاصيتين فلن يغير هذا شيئا إلا إذا وضعت القيمة ع1815 
في الخاصية .EnableHeadersVisua1Styles‏ 


كما يمدك جدول العرض بالوسائل التالية للتعامل مع الأعمدة: 


#ا- عدد الأعمدة المعروضة :Displayed ColumnCount‏ 
تعيد عدد الأعمدة الت اها المستخد الشاشة هذه اللحظة 
ير مم في و 
معامل منطقي» إذا خعلت قيمته ع1 فسيدخل ضمن العدد الأعمدة التي 
يظهر جزء منها فقط. 


7# تعديل طراز حافة عنوان العمود :AdjustColumnHeaderBorderStyle‏ 
تعدل شكل إطار رأس العمود.. وتستقبل هذه الوسيلة المعاملات التالية: 
- كائن طراز الحافة المتطور DataGridViewAdvancedBorderStyle‏ 
الخاص بالعمود الذي سيتم تعديله. 
- كائن طراز الحافة المتطور DataGridViewAdvancedBorderStyle‏ 
الذي سيستخدم لحفظ التغييرات البينية التي تحدث لرأس العمود. 
- معامل منطقي» أرسل إليه من إذا كان العمود هو أول عمود 
معروض في الجدول. 
- معامل منطقي» أرسل إليه 116 إذا كان العمود هو آخر عمود مرئي 
في الجدول. 
وة هة الوسيسيئلة كان طسو از العافسية الور 
Grid ViewAdvancedBorderStyle‏ الذي يمثل طراز الحافة المعدل. 
لاحظ أنك لست مضطرا إلى استخدام هذه الوسيلة يدوياء فجدول العرض 
يستدعيها تلقائيا لضبط شكل حواف الخانات الرئيسية للأعمدة عند رسمها. 


#< تحجيم العمود تلقائيا :AutoResizeColumn‏ 
تغير عرض العمود المطلوب» ليناسب محتويات خاناته.. ولها صيغتان: 
.١‏ الصيغة الأولى تستقبل رقم العمود المراد تحجيمه. 
؟. الصيغة الثانية تزيد على الصيغة السابقة بمعامل ثان» يستقبل إحدى قيم 
المرقم DataGrid ViewAutoSizeColumnMode‏ لتوضح طريقة 
تححيم العمود» وقد سبق فا التعرف علية. 


7 تحجيم تلقائي للأعمدة 01115 411601451766 : 


Ao 


تغير عرض جميع أعمدة الجدول لتلائم محتويات خاناتها.. ولها صيغتان: 

.١‏ الصيغة الأولى بدون معاملات. 

۲ 1 ب 0 الثائد 55 تقب( ى » ۴ | قم 
DataGridView AutoSizeColumnMode‏ لتوضح طريقة تحجيم 


الأعمدة. 


8#> تغيير ارتفاع رؤوس الأعمدة تلقائيا :AutoResizeColumnHeaders Heigt‏ 
تغير ارتفاع رءوس الأعمدة تلقائيا لتناسب محتوياتها.. ولها صيغتان: 
-١‏ الصيغة الأولى بدون معاملات» وهي تغير ارتفاع صف العناوين ليراعي 
7ك.والصيغة الثانية فل رقم العموة الذي بجحب مر اعا ريات خانة 
عنوانه عند تغيير ارتفاع الصف. 


#> معرفة مستطيل عرض العمود :GetColumnDisplay Rectangle‏ 
تعيد كائن مستطيل 16013816 يحتوي على موضع وأبعاد العمود المطلوب» 
وهي تستقبل معاملين: 

- رقم العمود المطلوب. 

د معامل متطقى إذا حولت فييكت دوز فقت هد الدسييلة اا 
العصيط ال م الروك مي السو كلس العا وان ا 
مه۴ فستعيد المستطيل المحيط بكامل العمود حتى لو كان جزء منه 
غير ظاهر على الشاشة. 


1# إبطال رسم العمود :InvalidateColumn‏ 
اسل إلى هذه الوسيلة رف العمود كوو ال رة فى اهدو »هنا 
يجبره على إعادة رسم نفسه من جديد. 


كما يمدك جدول العرض بالأحداث التالية للتعامل مع الأعمدة» علما بأن المعامل 
الثاني ع في معظم هذه الأحداث من النو ع دع تشاع مطل 0 )102120311017161» 
وهو يمتلك الخاصية 00110 التي تعيد كان العمود 
1100110 الذي سبب انطلاق الحدث.. لهذا لن نكرر ذكر هذا 
في الأحداث» وسنذكر نوع المعامل فقط إذا كان مختلفا: 


إضافة عمود :ColumnAdded‏ 
ينطلق عند إضافة عمود إلى جدول العرض. 


A“ 


3 حذف عمود :ColumnRemoved‏ 
ينطلق عند حذف عمود من جدول العرض. 


#2 تغير رقم عرض العمود :ColumnDisplayIndexChanged‏ 
ينطلق عندما تتغير قيمة الخاصية 1(150133:1206:2 الخاصة بأحد أعمدة 
جدول العرض سواء من الكودء أو بسبب سحب المستخدم للعمود من 
موضعة. 


النقر المزدوج على فاصل العمود :ColumnDivider DoubleClick‏ 
ينطلق عندما ينقر المستخدم مرتين بالفارة فوق الخط الفاصل بين عمودين» 
لتحجيم العمود تلقانيا لبذاسب محتويات.خاناته. . والمعامل الثاني ع لهذا الحدث 
من gill‏ ع <DataGridViewColumnDividerDoubleClickEventArgs‏ وهو 


ا يخي | ×ءلمآمص اه٤‏ | تعيد رقم العمود الذي نقره المستخدم بالفأرة. 


Button 7‏ تعيد إحدى قيم المرقم sرتاا Muse 8u‏ التي 
تخبرك بزر الفأرة الذي ضغطه المستخدم. 


E‏ بر Clicks‏ تعيد عدد مرات ضغط زر الفأرة. 

Delta E‏ تعيد عدد حركات عجلة الفأرة. 

X a7‏ تعيد الموضع الأفقي لمؤشر الفأرة. 

E‏ 0 تعيد الموضع الرأسي لمؤشر الفأرة. 

ف | 10205 أتعيد كائن النقطة ٤ماه۴؛‏ الذي يحمل موضع 
مؤشر الفأرة. 

اع | لالص8 | إذا جعلت قيمة هذه الخاصية 106 فلن تتخذ 


أية خطوات إضافية لمعالجة الحدث.. هذا معناه 














AY 





























#7 ضغط رأس العمود :ColumnHeaderMouseClick‏ 
ينطلق عند الضغط بالفأرة على رأس أحد أعمدة جدول العرض.. والمعامل 
الثاني م لهذا الحدث من النوع «DataGridViewCellMouseEventArgs‏ 
وهو يمتلك نفس خصائص الحدث السابق ما عدا الخاصية 11320160: كما 
يمتلك الخاصية :1101:1016 التي تعيد رقم الصف الذي توجد به الخانة 
المضغوطة.. لاحظ أن هذه الخاصية ستعيد ١-‏ في هذا الحدث» لأن صف 
رؤوس الأعمدة لا يدخل ضمن ترقيم صفوف الجدول. 


# النقر المزدوج على راس العمود :ColumnHeaderMouseDoubleClick‏ 
ينطلق عند النقر مرتين بالفأرة على أحد أعمدة الجدول.. والمعامل الثاني م 
لهذا الحدث من النوع DataGridViewCellMouseEventHandler‏ كما 
في الحدث السابق. 


# تغير حالة العمود :ColumnStateChanged‏ 
ينطلق عندما تتغير حالة العمود»ء كأن يفقد المؤشر 100115 1,056.. والمعامل 
الثاني e‏ من gill‏ ع DataGridViewColumnStateChangedEventArgs‏ 
وهو يمتلك الخاصيتين التاليتين: 


Column |٠ 289‏ | تعيد كائن العمود DataGridViewColumn‏ 
9 ون | 0ء5]3601328 | تخبرك بالحالة الجديدة للعمود» وهي تعيد إحدى 
قل سيوم اله ركم 
DataGrid ViewElementStates‏ الذي 
ترا عا من أل عند التغرف على الخاصية 

.DataGridViewElement. State 














تغير عرض العمود :ColumnWidthChanged‏ 
ينطلق عندما تتغير قيمة الخاصية طا ل۷ الخاصة بأحد أعمدة جدول 
العرضء سواء برمجيا أو بواسطة المستخدم. 


AA 











التعامل مع صفوف جدول عرض البيانات: 
يمنحك جدول العرض الخصائص التالية للتعامل مع الصفوف: 


عدد الصفوف :R‌oW Cou)‏ 
تقرأ أو تغير عدد صفوف جدول العرض.. ولو وضعت في هذه الخاصية قيمة 
أكبر من عدد صفوف الجدول» فسيضيف هذا صفوفا جديدة إلى نهاية الجدولء 
بينما يؤدي وضع قيمة أصغر من عدد صفوف الجدول إلى حذف صفوف من 
نهاية الجدول» ولو وضعت في هذه الخاصية القيمة صفر فستمحى كل 

الط 


7 فع الصفوف :R0 Ws‏ 
تعيد مجمو عة الصفوف DataGrid View RowCollec†10o٣‏ التي تحتوي 
على كائنات صفوف جدول العرض ..DataGridViewRow Objects‏ 
وكل صف تضيفه إلى هذه المجموعة يظهر في جدول العرض» وكل صف 
تحذفه منها يختفي من جدول العرض.. وتبدأ الصفوف في هذه المجموعة 
بالصف رقم صفرء وهو أول صف بعد صف رؤوس الأعمدةء وتنتهي هذه 
المجموعة بالصف الجديد إذا كان مسموحا بعرضه في جدول العرضء أو 
بآخر صف حقيقي يحتوي على بيانات إن كان جدول العرض لا يعرض 

الصف الجديد. 
لاحظ أن صف رؤوس الأعمدة هو الصف رقم -٠ء‏ لكنك لا تستطيع التعامل 
امن خان هذه الخاضية: و ا تحصل لى الرق ١‏ من الوسيائل 
والأحداث التي تخبرك برقم الصف الذي حدث له تغير معين» كما سنرى فيما 
يلي.. وبدلا من هذا ويمكن التعامل مع أي خانة في صف الرءوس باستخدام 
الخاصية 30610:611ع11 لكل عمود.. والمثال التالي سيخبرك أن خانة رأس 
العمود الأول توجد في الصف رقم :١-‏ 
MsgBox(DGAuthors.Columns(0).HeaderCell.RowIndex)‏ 
ويريك الزر "عكس التحديد" في المشروع DataGridView AuthorBooks‏ 
مثالا على كيفية استخدام المجموعة 120175 لعكس تحديد الصفوف جدول 
العرضءوذلك بالمرور على كل صفوف الجدول» وعكس قيمة الخاصية 
Selected‏ لکل منها. 


۸۹ 


57 لز الصفوف المحددة :Selected Rows‏ 
تعيد مجموعة الصفوف المحددة «DataGridViewSelectedRowCollection‏ 
وهي مجموعة ترث الفئة 83560011610100 وتمثل واجهة القائمة 1].15]6]» 
وتحتوي على الأعمدة المحددة حاليا في الجدول.. لاحظ أنك لا تستطيع إضافة 
ضفرف إلى هذه الح عة لأا لر اء فقط ولا شلك الرس ال لهذا ك 
أردت تحديد أحد الصفوف» فضع القيمة 1506 في الخاصية 0م]ع5616 
الخاصة بهذا الصف.. والكود التالي يحدد الصف الأول: 
Dgv.Rows(0).Selected = True‏ 
لكن هذا لن يزيل تحديد الصفوف المحددة سابقاء لهذا لو أردت فعل هذاء 
فعليك المرور عبر كل الصفوف المحددة ووضع القيمة ع1"215 في الخاصية 
ectedاeك‏ الخاصة بكل منها: 
Do Until DGAuthors.SelectedRows.Count = 0‏ 
Dgv.SelectedRows(0).Selected = False‏ 
Loop‏ 
Dgv.Rows(0).Selected = True‏ 
لاحظ أن إزالة تحديد الصف الأول يحدث مجموعة الصفوف المحددة لإزالته 
منهاء لهذا نستمر في حذف الصف الأول من هذه المجموعة دائما إلى أن 
تفرغ نهائيا من محتوياتها. 
وهناك طريقة أخرى أكثر كفاءة» وهي وضع مجموعة الصفوف المحددة في 
متغير» وإزالة تحديد كل عناصرها.. صحيح أن المتغير يشير إلى مجموعة 
الصفوف المحددة مرجعياء والمفروض أن يرى التغييرات التي تحدث لهاء 
لكن جدول العرض يلغي المجموعة كلها إذا تغير تحديد أي صف وينشئ 
مجموعة جديدة ويضف إليها الصفوف المحددة؛ لهذا يظل المرجع الذي 
وضعناه في المتغير يشير إلى المجموعة القديمة.. لعل هذا يوضح لك لماذا 
يكون التعامل مع المجموعة 56160160190175 مكلفا جدا إذا كان جدول 
العرض يحتوي على عدد هائل من الصفوف» فتحديث جدول العرض لهذه 
المجموعة عملية تتسم بعدم الكفاءة! | 
وستجد الكود التالي في الزر "تحديد الصف الأول" في المشروع 
«DataGridViewAuthorBooks‏ وهو يزيل تحديد كل الصفوف المحددة» ثم 
يحدد الصف الأول في جدول العرض: 
Dim SelRows = DGAuthors.SelectedRows‏ 
For Each R As DataGridViewRow In SelRows‏ 
R.Selected = False‏ 
Next‏ 
DGAuthors.Rows(0).Selected = True‏ 


وخ قالب الصف :RowTemplate‏ 

تقرأ أو تغير كائن الصف ۸0W‏ ء46۲14۷1( الذي يستخدم كقالب تستمد 
منه الصفوف الجديدة خصائصها.. هذا مفيد إذا أردت تغيير شكل كل صفوف 
الجدول ووضع اا کیو ا فكل ما علباك هو العريفت كات 
صف جديد وضبط خصائصه ثم وضعه في هذه الخاصية.. ويمكنك فعل هذا 
في وقت التصميم باستخدام نافذة الخصائصء» فلو ضغطت العلامة + 
المجاورة لاسم هذه الخاصية» فستظهر بعضص الخصائص الفرعية للصف الذي 
يعمل كقالب» ما يتيح لك التحكم في القائمة الموضعية للصف وارتفاعه 
وعرض الفاصلء كما يمنك استخدام الخاصية 1(61911160611516716 للتحكم 
شكل خانات الصف.. وقد فعلنا هذا في جدول العرض الموضوع على 
النموذج 00[1 2ط في المشروع 501100[15]تخ.:102120110171615» 
لجعل لون خلفية الخانات اصفرء ولون الكتابة أحمر. 


وه السماح للمستخدم بإضافة صفوف :AllowUserToAdd Rows‏ 
إذا جعلت قيمة هذه الخاصية 1:36 (وهي القيمة الافتراضية)» فسيعرض 
جدول العرض صفا إضافيا فارغا في نهاية الجدول» وعند تحرير المستخدم 
لأي خانة من خاناته يضاف هذا الصف إلى الجدول» ويضاف بعده صف 
جديد فار ع. 


57 ف رقم الصف الجديد :NewRowIndex‏ 
تعيد رقم الصف الجديد في جدول العرض (آخر صف في الجدول).. لاحظ أن 
هذه الوسيلة ستعيد ١-‏ إذا لم يكن مسموحا للجدول بعرض صف جديد. 


وخ السماح للمستخدم بحذف الصفوف :AlIlowUser1[oDelete Rows‏ 
إذا جعلث قيمة هذه الخاصسية 6ن1 (وهي القيمة الافتراضية): فسيتمكن 
المستخدم من حذف الصف المحدد في جدول العرض بضغط الزر ع1(616 
من لوحة المفاتيح. 


وخ السماح للمستخدم بتحجيم الصفوف :AllowUserToResizeRows‏ 
إذا جعلت قيمة هذه الخاصية م1 (وهي القيمة الافتراضية)» فسيتمكن 
المستخدم من تغيير ارتفاع الصف بسحب حافته بالفأرة. 


7 فز الصف الحالي :CurrentRow‏ 
تعيد كائن الصف :1731301101/161713017 الذي يحتوي على الخانة التي بها 
المؤشر 10011560 حاليا. 


<۹۱ 


وخ طريقة التحجيم التلقائي للصف :AutoSizeRowsMode‏ 
تحدد كيف سيتم تغيير ارتفاع صفوف جدول العرض تلقائياء وهي تأخذ إحدى 
قيم المرقم ع10212013017161:.411]05126190151/100 التالية: 


None 
AllCells 


AllCells 
ExceptHeader 
AllHeaders 


DisplayedCells 
DisplayedCells 


ExceptHeaders 
DisplayedHeaders 








لا يتم تغيير ارتفاع الصفوف تلقائيا. 

تغيير ارتفاع كل صف ليناسب محتويات جميع 
خاناته» بما فيها الخانة الرئيسية ل14 . 

تغيير ارتفاع كل صف ليناسب محتويات جميع 
حاتائه» ما عذا الخاثة الرئيسية. 

تغيير ارتفاع كل صف ليناسب محتويات الخانة 
الرئيسية. 

تغيير ارتفاع كل صف ليناسب محتويات خاناته 
المع وة على اللاك ينا فيها الخانة الرئيسية. 
تغيير ارتفاع كل صف ليناسب محتويات خاناته 
المعروضة على الشاشة؛ ماغدا الخانة اثر تة 
تغيير ارتفاع كل صف ليناسب محتويات الخانات 
الرئيسية المعروضة على الشاشة. 


7 ف هل الصف الحالي قذر :IsCurrentRowDirty‏ 
مصدر البيانات.. لاحظ أن التغييرات التي أجراها المستخدم يتم حفظها في 
مضدر البيانات فى الحالات الثالية: 

- فور مغادرة الصف الحالي إلى صف آخر. 
- إذا ضغط المستخدم ع1م01+12) من لوحة المفاتيح وهو ما زال في 


الصيقه الحالن. 


- إذا قمت باستدعاء الوسيلة هلاه ۴٠۲.۷‏ الخاصة بالنموذج الذي 
يوجد عليه جدول العرض. 
- إذا كان جدول العرض مرتبطا بمصدر ربط BindingSource‏ 
واستدعيت الوسيلة 22011016 الخاصة به. 
وقد استخدمنا هذه الخاصية في المشروع CustomDataSet‏ في الحدث 
»e11٣ntentClick‏ وذلك لحفظ بيانات التلميذ الحالي في مجموعة 
البيانات قبل عرض درجاته» حتى لا يحدث خطأ عند محاولة التعامل معها.. 
هذا هو الكود الذي يفعل هذا: 
If DgStudents.IsCurrentRowDirty Then‏ 


<۹۲ 





























إنهاء التحرير ' ( DgStudents.EndEdit(‏ 
إجبار جدول العرض على نقل التغييرات إلى مجموعة البيانات ' 
Me.Validate( )‏ 

End If 


وخ رقم أول صف معروض :FirstDisplayedScrolIlingRow1ndex‏ 
تعيد رقم أول صف معروض حاليا على الشاشة.. ويمكنك أيضا أن تضع فيها 
رقم الصف الذي تريد الانزلاق إليه ليصير أول صف معروض. 


3 هل رؤوس الصفوف مرئية :RowHeaders Visible‏ 
إذا جعلت قيمة هذه الخاصية ع7219» فلن يظهر العمود الذي يحتوي رؤوس 
صفوف الجدول.. والقيمة الافتراضية هي ©111. 


ونج عرض ربوس الصفوف :RowHeaders Width‏ 
تقرا أو تغير عرض العمود الذي يحتوي رؤوس صفوف الجدول. 


3 طريقة تغيير عرض رؤوس الصفوف :RowHeadersWidthSize Mode‏ 
توضح كيف يتم ضبط عرض ر ءوس الصفوف» وهي تأخذ إحدى قيم المرقم 
Data GridViewRowHeaders WidthSizeMode‏ التالیة: 


ngښEnableResi‏ | يمكن للمستخدم تغيير عرض رؤوس الصفوف 
بسحبها بالفأرة. 
8 الا يستطيع المستخدم تغيير عرض رؤوس 
الصفوف. 
AutoSizeTo‏ ضبط عرض رؤوس الصفوف تلقائيا لتناسب 
AllHeaders‏ محتوياتها. 
AutoSizeTo‏ ضبط عرض رؤوس الصفوف الظاهرة على 
75+ االشاشة تلقائيا لتناسب محتوياتها. 
AutoSizeTo‏ ضبط عرض عمود رؤوس الصفوف ليناسب 
FirstHeader‏ محتوى أول خانة فيه. 











وغ طراز حافة رؤوس الصفوف :RowHeadersBorderStyle‏ 
©3551 الذي تعرفنا عليه من قبل. 


و تعبا الطراز الافتراضي لخانات رؤوس الصفوف :RowHeadersDefau[tCe1IStyle‏ 


تدك 




















تقرأ أو تغير كائن طراز الخانة 611565:16 123120611057160 الذي يتحكم 
في شكل رؤوس الصفوف. 
9 يخ الل راز المتقدم لواف رؤوس اأص فوف 
:AdvancedRowHeadersBorderStyle‏ 
تعيد كائن الطراز المتقدم DataGridViewAdvancedBorderStyle‏ 
الذي يتحكم في شكل إطار رؤوس الصفوف. 


يونعم الطر از الافتراضي لخانات الصفوف :RowsDefaultCe1IStyle‏ 
تقرأ أو تغير كائن طراز الخانة 1231200110171617061156716 الذي يتحكم 
في كل خانات صفوف الجدول: 


5 ادف رز الافتراضي التبادلي لخانات الصفوف 
:AlternatingRowsDefaultCellStyle‏ 
تقرأ أو تغير كائن طراز الخانة 1eر†؟11‏ € wء‏ 1۷1 6هtهD‏ الذي يتحكم 
في شكل خانات الصفوف الفردية في الجدول.. لاحظ أنك لو وضعت قيمة في 
هذه الخاصية»ء فستتحكم الخاصية عRowsDefau1tCe11Sty1‏ في شكل 
خانات الصفوف الزوجية فقط بينما تتحكم الخاصية 
2-56 في شكل خانات الصفوف 
الفردية.. لكي ترى تأثير هذاء افتح نافذة الخصائص وحدد هذه الخاصيةء 
لجعل لون الخلفية 18201200101 للصفوف التبادلية فضيا 5110701.. سيؤدي 
هذا إلى أن يعرض الجدول صفا خلفيته بيضاء يليه صف خلفيته فضية ثم 
صف خلفيته بيضاء وهكذاء كما هو موضح في الصورة: 


About | Phone | CountryID Author | 





توفيق الحكيم 
عباس العقاد 


| فاروق جويدة 
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5 عرض أخطاء الصفوف :‘ShowRowErrors‏ 
إذا جعلت قيمة هذه الخاصية 1:16 (وهي القيمة الافتراضية)» فستظهر أيقونة 
الخطأ في خانة رأس الصف الذي توجد فيه أخطاء. 


3 عرض أيقونة التحرير :ShowEditingIcon‏ 


5 











إذا جعلت قيمة هذه الخاصية ع1" (وهي القيمة الافتراضية)» فستعرض 
خانة رأس الصف أيقونة على شكل قلم» عندما يحرر المستخدم قيمة أي خانة 
في الصف. 


وخ نظام الترتيب :S0۲٤0 der‏ 
تحدد اتجاه ترتيب صفوف جدول العرضء وهي تأخذ إحدى قيم المرقم 
:101 التي تعرفنا عليها سابقا. 


كما يمدك جدول العرض بالوسائل التالية للتعامل مع الصفوف: 


7# تحجيم الصف تلقنايا 41160126512612018: 
تضبط ازتفاع الصف الذي ترسل إليها ر فة كمعامل» ليناسب محتوياك خاناكة: 
وتوجد صيغة أخرى لهذه الوسيلة» تستقبل إحدى قيم المرقم 
1-100 التي توضح كيف يتم تغيير 
ارتفاع الصفء وقد تعرفنا على هذا المرقم سابقا. 


7# تحجيم الصو تلقائيا :Auto Resize Rows‏ 
تضبط ارتفاع جميع صفوف جدول العرض» لتناسب محتويات خاناتها. 
وتوجد صيغة أخرى لهذه الوسيلة تستقبل إحدى قيم المرقم 
ViewAutoSize Row Mode‏ التي توضح كيف يتم تغيير 
ارتفاع كل صفء وقد تعرفنا على هذا المرقم سابقا. 


7# تحجيم عرض رؤوس الصفوف تلقائيا :AutoResizeRowHeaders Width‏ 
تضبط عرض العمود الذي يحتوي على رؤوس الصفوف» وهي تستقبل إحدى 
قيم المرقم ›DataGridViewRowHeaders WidthSizeMode‏ التي 
توضح كيف يتم تغيير عرض رؤوس الأعمدة» وقد تعرفنا عليه سابقا. 
وتوجد صيغة أخرى لهذه الوسيلة» تزيد على الصيغة السابقة بمعامل أول؛ 
يستقبل رقم الصف الذي تريد ضبط العرض تبعا لمحتويات خانته الرئيسية. 


7# عدد الصفوف المعروضة :Displayed RowCount‏ 
تعيد عدد الصفوف التي يراها المستخدم على الشاشة في هذه اللحظة؛ ولها 
معامل منطقي» إذا جعلت قيمته ع1" فسيدخل ضمن العدد الصفوف التي 
يظهر جزء منها فقط, 


1#> معرفة مستطيل عرض الصف :GetRowDisplay Rectangle‏ 
تعيد كائن مستطيل و1ع126013 يحتوي على موضع وأبعاد الصف المطلوب» 
وهي تستقبل معاملين: 
د وك الضف المطازيه 
عامل مط إذا حت فده ورور فمو عت الزسزلة اسان 
المحيط تال رد النسووكض من السقه عى ها ا 
56 : فستعيد المستطيل المحيط بكامل الصف حتى لو كان جزء منه 
< إبطال الصف :InvalidateR‌ow‏ 


أرسل إليها رقم الصفء لتقوم بإبطال رسمه في الجدول» مما يجبره على 
إعادة رسم نفسه من جديد. 


كما يمدك جدول العرض بالأحداث التالية للتعامل مع الصفوف» علما بأن المعامل 
الثاني ع في معظم هذه الأحداث من gill‏ ع «DataGridViewRowEventArgs‏ 
وهو يمتلك الخاصية سه۸ التي تعيد كائن العمود 12312001101716112015 الذي 
سبب انطلاق الحدث: 


#۶ تغير نص خطأ ا :RowErrorTextChanged‏ 
ينطلق عندما 33 تتغير قيمة الخاصية Error [cext‏ في أحد صفوف الجدول. 


۶۶ تغير عرض رؤوس الصفوف :RowHeadersWidthChanged‏ 


ينطلق عند تغيير عرض العمود الذي يحتوي على رؤوس الصفوف» سواء 
بواسطة المستخدم أو من الكود. 
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# تغير ارتفاع الضت :RowHeightChanged‏ 
ينطلق عندما تتغير قيمة الخاصية ؛راعزء11 الخاصة بأحد صفوف الجدول» 
سواء بواسطة ا أو من الكود. 


# تغير حالة الصف :RowStateChanged‏ 
ينطلق عند تغير حالة الصف» مثلما يحدث عند استقباله المؤشر الضوئي 
615 أو فقدانه له.. والمعامل الثاني م لهذا الحدث من النوع 
وع تشغطء0187عع ننقط )ه21 123130110171611201:5» وله الخاصيتان التاليتان: 


DataGridView Row تعيد كائن الصف‎ Row E7 
تخبرك بحالة الصف التي تغيرت» وهي تعيد‎ | Stat eChanعeعd‎ | بهن‎ 5 
DataGridViewElementStates إحدى قيم المرقم‎ 
التي تعرفنا عليها من قبل.‎ 
على سبيل المثال» لو كان الصف الثاني محددا وغادرته لتحدد الصف الأولء‎ 
فإن الحدث 11015126003860 سينطلق مرتين كالتالي:‎ 
اد المرة ال لي سيف كر ا سيد الصف القن ,تفن الحا‎ 
e.StateChanged إلى الصف الثاني» وستكون للخاصية‎ 77 
.Sع1عء)عإ القيمة‎ 
؟- المرة الثانية بسبب تغير حالة تحديد الصف الأول» وستشير الخاصية‎ 
إلى الصف الأول؛ وستكون للخاصية 0ع51236601208.©‎ 7 
.Sع1عء)عإ القيمة‎ 














#7 ضغط رأس الصف :RowHeaderMouseClick‏ 

ينطلق عندما يضغط المستخدم رأس الصف بالفأرة.. والمعامل الثاني م لهذا 
الحدث من النوع DataGrid ViewCellIMouse EventArgs‏ الذي تعرفنا 
عليه سابقا.. وقد استخدمنا هذا الحدث في المشروع لعرض القائمة الموضعية 
المناسبة عند ضغط المستخدم لرأس الصف.. لاحظ أننا لا نستطيع استخدام 
قوائم موضعية ثابتة في وقت التصميم» » لأننا نعرضها فقط إذا حدث خطأ في 
حفظ الصف الحالي في قاعدة البيانات» كما أن نوع القائمة يختلف تبعا لنوع 
الخطا. . وقد استخدمنا المعامل 18057110162.» للحصول على كائن الصف 
من مجمو عة الصفوف: 

Dim R = DgAuthors.Rows(e.RowIndex) 


۹۷ 











ومن ثم استخدمنا الوسيلة ع[ع2ه]عء1335:1:6م061120771015 الخاصة بجدول 
العرض لمعرفة موضع هذا الصف» وذلك لاستخدامه في تحديد موضع القائمة 
الموضعية: 
Dim Pos - 2)‏ 
e.RowIndex, False).Location‏ 
بعد هذا فحصنا نص الخطأ الخاص بالصف.. ونظرا لأن نص الخطأ الذي 
نضعه فى الخاصية ErrorText‏ الخاصة بصف مجموعة البيانات ينتقل كما 
هو إلى الخاصية :110116 الخاصة بصف جدول العرضء فقد فحصنا 
بعض الكلمات التي كتبناها لشرح الخطأء لنعرف منها نوع هذا الخطأ: 
If R.ErrorText.Contains("4dذ>'"") Then‏ 
InsertCntxt.Show(DgAuthors, Pos + e.Location)‏ 
Elself R.ErrorText.Contains("4dıدعûڊ'"") Then‏ 
UpdateCntxt.Show(DgAuthors, Pos + e.Location)‏ 
End If‏ 
لاحظ أن موضع مؤشر الفأرة الذي تعيد الخاصية 1.002010.ء يكون منسوبا 
إلى نقطة رأس الصف.. لهذا علينا أن نجمع عليه موضع رأسي الصف ليكون 
منسوبا إلى النموذج ككل. 


#2 النقر المزدوج على راس الصف :RowHeaderMouseDoubleClick‏ 
ينطلق عندما ينقر المستخدم رأس الصف مرتين بالفأرة.. والمعامل الثاني م 
لهذا الحدث من النوع .DataGridViewCellMouseEventArgs‏ 


۶ النقر المزدوج على فاصل الصف :RowDivider DoubleClick‏ 
ينطلق عندما ينقر المستخدم مرتين بالفأرة فوق الخط الفاصل بين صفين» 
لتحجيم ارتفاع الصف تلقائيا ليناسب محتويات خاناته.. والمعامل الثاني م لهذا 
الحدث من النوع «DataGridViewRowDividerDoubleClickEventArgs‏ 
وهو يمتلك الخصائص التالية: 
20120161 | تعيد رقم الصف الذي نقره المستخدم بالفارة. 
0 اتعيد إحدى قيم المرقم 72101151810005 التي 
تخبرك بزر الفأرة الذي ضغطه المستخدم. 
15 | تعيد عدد مرات ضغط زر الفأرة. 
2 /تعيد عدد حركات عجلة الفأرة. 
XxX‏ تعيد الموضع الأفقي لمؤشر الفأرة. 
37 تعيد الموضع الرأسي لمؤشر الفأرة. 
)ا تعيد كائن نقطة دزم » به موضع مؤشر الفأرة. 
Handled‏ | اذا جعلت قيمتها مںإ1» فلن تتخذ أية خطوات 
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إضافية لمعالجة الحدث.. هذا معناه إلغاء عملية 














# قبل رسم الصف :RowPre Paint‏ 
ينطلق قبل رسم أحد صفوف جدول العرض» ليتيح لك التدخل في طريقة 
رسمه.. والمعامل الثاني ع لهذا الححدث من النوع 
DataGridView RowPrePaintEventArgs‏ وهو يمتلك الخصائص التالية: 


بو | RowIndex‏ | تعيد رقم الصف. 

2 ون | 25080205 | تعيد كائن المستطيل عاع مم26 الذي يحمل 
موضع وأبعاد الصف. 

5 | ولرنه80م011) |تقرأأو تغير كائن المستطيل واعمماءه :1 
الذي يحمل موضع وأبعاد المساحة التي يجب 
اغا رسمها شن حدول الغرطن.. لأحظ أن 
هذه المساحة قد تختلف عن مساحة الصف› 

فمثلا قد تخفي نافذة أخرى جزء! من جدول 
العرض» وعند اختفاء هذه النافذة يحتاج الجزء 
الذي غطته إلى إعادة رسمه لإنعاشه. 

2ه 8202166 2 | تعيد نص الخطأ الخاص بالصف. 

ير Graphics‏ تعيد كائن الرسوم 1105م06173 الذي سيستخدم 
لسع الصيف. 

DataGrid ViewCelIStyle تعيد طراز الخانة‎ Inherited E 
الذي يتحكم في شكل خانات الصف.. وهي‎ +551 
تماثل الخاصية 1016111605116 الخاصة‎ 
بكائن الصف» لكن استخدام كائن الصف في‎ 
حدث الرسم يؤدي إلى بطء تنفيذ البرنامج» لذا‎ 
InheritedRowStyle يفضل استخدام الخاصية‎ 
لضمان أحسن أداء.‎ 

IsFirst a3‏ تعيد 16" إذا كان الصف المراد رسمه هو 
6012057 أ ول صف ظاهر على الشاشة. 

IsLast a5‏ تعيد 116 إذا كان الصف المراد رسمه هو 
607 أآخر صف مرئي في جدول العرض. 

State a5‏ تعيدإحدى قي المرقم 
Data GrıdViewElementStates‏ التي توضح 
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Pinta | 5‏ | تحدد الأجزاء التي يجب على جدول العرض 

رسمها في كل خانة من خانات الصفء وهي 

تأخذ إحدى قيم المرقم 

10712215 التالية: 

:Non8 -‏ لا يتم رسم الخانة. 

"All -‏ رسم كل أجزاء الخانة.. هذه هي 
القيمة الافتراضية. 

ground -‏ 1ء823: رسم خلفية الخانة. 

:B order -‏ رسم إطار الخانة. 

:ContentBackground -‏ رسم خلفية 

- 81011120 0011611417016): رسم لون محتوى 
الخانة. 

:Error1co -‏ رسم أيقونة الخطأ. 

- 1”06115: رسم المستطيل الذي يشر إلى أن 
الخانة بها العلامة الضوئية 15اع1'0. 

:SelectionBackground =‏ رسم خلفية التحديد. 

وتستطيع دمج أكثر من قيمة من هذه القيم معا 

باستخدام المعامل 0. 

Handled‏ اجعل قيمتها 1506" لتخبر جدول العرض بأن 

حدث الرسم قد تمت الاستجابة له كلياء ولن 

ينطلق الحدث غمزج 12012052 ولا الحدث 

عمتامنج6112.. لا تستخدم هذه القيمة إلا إذا 

أردت إلغاء رسم الصف بواسطة جدول 

العرضء وفي هذه الحالة عليك أن ترسمه أنت 

بنفسك من داخل هذا الحدث. 


كما يمتلك المعامل م الوسائل التالية» التي تتيح لك التحكم في رسم مكونات 











الصف بنفسك* 
DW ۴٥u | >‏ ترسم مستطيلا حول المنطقة التي تريدهاء وهي 
- كائن المستطيل ع1عمه]ء26 الذي سيتم رسم 
الآطان حولة 



































PaintCells 


PaintCells 
Background 


PaintCells 
Content 





- معامل منطقي» > ذا جعلته عںإآ يتم تلوين 
الممسستلطيل بلون خلفية التحديد 
10101 »: وإذا جعلته False‏ 
..Back 0٣‏ وكلا اللونين يحددهما طراز 
الصف .DataGridViewRow.InheritedStyle‏ 

ترسم خانات الصف» وهي تستقبل معاملين: 

- كائن المستطيل ع1[ع2ة1ع6 2 الذي يحتوي على 
موضع وأبعاد المساحة التي يراد رسم خاناتها. 

- إحدى ة قيم المرقم DataGridViewPaintParts‏ 
الشى تو > الأجزاء المراد رسمها من الخانات. 

ترسم خلفية خانات الصف» وهي تستقبل معاملين: 

- كائن المستطيل عاعمهاءءR‏ الذي يحتوي على 
ومو أيغاد المساحة التى دراد رين خاداتها. 

- معامل منطقي» > إذا جعلته عرم1' يتم تلوين 
الممسستطيل بلون خلفية التحديد 
2221 :؛: وإذا جعلته False‏ 
يتم تلوين المستطيل بلون الخلفية 010۲ 84c)‏ . 

ترسم محتويات خانات الصف» وهي تستقبل كائن 

المستطيل ء08[1 ]160 الذي يحتوي على موضع 

رأة المساحة التي وو اذ رسع سحتو ياك ها 




















= ال14 Paint‏ | ترسم خانة رأس الصف» ولها صيغتان: 

-١‏ الأولى تستقبل معاملا منطقياء إذا جعلته ں1 
يتم تلوين خلفية رأس العمود بلون خلفية 
التحديد» وإذا جعلته ع1219 يتم تلوينه بلون 
الخلفية. 

١‏ - الصيغة الثانية تستقبل إحدى قيم المرقم 
172125 التي توضح 











# بعد رسم الصف :RowPostP aint‏ 
ينطلق بعد رسم أحد صفوف جدول العرض.. والمعامل الثاني م لهذا الحدث 
من النوع وع تشطغخمء15خمنه1233011017716115015:20512 وهو يمتلك نفس 
الوسائل والخصائص كما في الحدث السابق ما عدا الخاصيتين يجمه" 
و .Handled‏ 
وک الت ارس م كط هر ل اليف لحا 
Current Row‏ في جدول العرض. 


Form1 ron Or ES 
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الاسم العنوان رقم الهاتف 














لاحظ أن جدول العرض يطلق هذا الحدث كلما كانت هناك ضرورة لإنعاش 

رسم الصف (كأن يختفي جزء من النافذة» أو يتم تكبيرها أو تصغيرهاء أو 

يتحرك المنزلق فيعرض أو يخفي جزءا من الصف... إلخ).. ونظرا لأن هذا 

الحدث ينطلق بعدد الصفوف الظاهرة على الشاشة كلما دعت الحاجة لرسمهاء 

فعليك أن تفحص معاملات الحدث لتتأكد من أن رقم الصف المرسوم هو رقم 
الصف الحالي: 

Dim Row = DataGridView1.CurrentRow ' الصف الحالي‎ 

If Row Is Nothing Then Return ' لا يوجد صف محدد حاليا‎ 

If Row.Index < > e.RowIndex Then Return 


0.۲ 














بعد هذا يمكنك أن ترسم مستطيلا حول الصف.. لفعل هذا استخدم الخاصية 
5 لمعرفة إحداثيات المستطيل المحيط بالجزء الظاهر على 
الشاشة من الصف.. واستخدم الخاصية 1105م013.© للحصول على كائن 
الرسوم الخاص بالصف» لتقوم بواسطته بعملية الرسم. 
إلى هنا وكل شيء بسيط.. لكن هناك بعض اللمسات التي يجب وضعها حتى 
يظهر المستطيل بشكل صحيح: 
- فمن الأفضل ألا يحتوي المستطيل على خانة رأس الصف 36ه1]].. لهذا 
سنطرح من عرض المستطيل عرص هذه الخانة» ويمكن معرفته باستخدام 
الخاصية .DataGridView.RowHeaders Width‏ 
- ليست هناك مشكلة إن كان عرض الصف أكبر من عرض جدول العرض 
(في هذه الحالة يظهر المنزلق الأفقي)» فكائن الرسوم سيرسم المستطيل 
a a‏ العرطن؛ SE‏ إن تعظية عرظيا كيزا جدا.. 
من عرض جدول الخ ففي ١‏ هذه الك م ا فق افق اذ 
کول العو کن كلة مر أكين ف ر طن للخل هدوا اة 
علينا أن نطرح من عرض المستطيل الفارق بين عرض الصف وعرض 
ج ‏ دول الع سرض.. لتنفهي ذ هذاء يجب 
أن نتأكد أن آخر عمود في الجدول (وهو العمودرقم 
1 - 135.601 1031301101/16157.60) معروض على الشاشة حاليا 
باستخدام الخاصية 1015013360 الخاصة بكائن العمود.. ثم نستخدم 
الوسيلة DataGrid View.GetColumnDisplayRectangle‏ لنحصل 
على المستطيل الذي يحمل أبعاد هذا العمود.. هذه الوسيلة تستقبل رقم 
العمود» ولها معامل ثان إذا جعلته ع11»؛ فإنها تعيد أبعاد الجزء 
المعروض من العمود وتستبعد المساحة المختفية من العمود.. هذا هو ما 
نريده هنا: 
Dim X1 =0‏ 
Dim I = DataGridView1.Columns.Count - 1‏ 
If DataGrid View1.Columns(I).Displayed Then‏ 
Dim ColRect = DataGridView1.‏ 
GetColumnDisplay Rectangle(I, True)‏ 
X1 = ColRect.Left‏ 
End If‏ 
القيمة 1> التي حصلنا عليها في الكود السابق» سنطرحها من عرض 
المستطيل الذي سنرسمه. 


غ ا كدرل کی يون بين ن 
إلى اليسارء فسنحتاج أيضا إلى تعديل موضع الحافة اليسرى للمستطيل 
ليبدأ من الحافة اليسرى للعمود الأخير.. أي القيمة 1× التي حصلنا عليها 
في الكود السابق! ١‏ 

- نظرا لأن جدول العرض قد يحتوي على منزلق رأسيء فيجب أن نطرح 
عرض هذا المنزلق من 1>.. يمكننا معرفة عرض المنزلق الرأاسي من 
معلومات نظام التشغيل باستخدام: 

SystemInformation. VerticalScrollBarW1idth 

لكن قبل أن نطرح هذه القيمة» يجب أن نعرف أولا إن كان المنزلق الرأسي 

معروضا أم لا.. يمكننا أن نعرف هذا إذا مررنا على جميع صفوف الجدولء 

لنجمع ارتفاعاتها فإن كانت أكبر من ارتفاع جدول العرضء فهذا معناه أن 
هناك خاجة لعروضن المنزلق الراسي.. لكن:علينا أيضا أن فحص قينة 
الخاصية 1731201101/1615/1.501011815 لنتأكد أن عرض المنزلق 

الرأسي مسموح به.. هذا هو الكود الذي يفعل هذا: 

Dim X2 =0 
Dim RowsHeight = 0 
If DataGrid View1.ScrollBars = ScrollBars.Both OrElse 
DataGridView1.ScrollBars = ScrollBars.Vertical Then 
For Each R As DataGridViewRow In DataGridView1.Rows 
RowsHeight += R.Height 
Next 
If RowsHeight > DataGrid View1.Height Then 
X2 = SystemInformation.VerticalScrollBarWidth + 4 
End If 
End If 
والآن دعنا نعرّف القلم الذي سنرسم به» وليكن لونه بنيا:‎ 
Dim pen As New Pen(Color.Brown) 
Dim penWidth As Integer = 2 
pen.Width = penWidth 
والآن دعنا نحسب أبعاد المستطيل الذي سنرسمه.. لاحظ أنا سنأخذ سمك خط‎ 
الرسم في حساباتنا:‎ 


Dim X = If(X1 = 0, Rect.Left + (penWidth \ 2), X1) 
Dim Y As Integer = Rect.Top + (penWidth \ 2) 
Dim W As Integer = Rect. Width - penWidth — 
DataGridView1.RowHeadersWidth - (X1 - X2) 
Dim H As Integer = Rect.Height - penWidth 
أخيرا لم يبق إلا أن نرسم المستطيل حول الصف:‎ 
e.Graphics.DrawRectangle(pen, X, Y, W, H) 
لق جرت هذا الكورد فستوئ المستطيل- يظذهر خول الضيفه الحالى: لكنك كلها‎ 
انتقلت من ضف إلى آخر+ رأة أحزاء من المستطيل: ما زات حول الصنفت‎ 
الفاق ها قد اظن المستطيل حول الصيفك لخدف‎ 
نحتاج إذن إلى طريقة لمحو المستطيل تماما من الصف السابق.. يمكن فعل‎ 
هذا في الحدث م1عم120112» الذي ينطلق قبيل دخول صف جديد.. في هذا‎ 
إلى الصف‎ DataGrid vView.CurrentRow الحدث تشير الخاصية‎ 
السابق» بينما تشير الخاصية ×علمآس۸0.ء إلى رقم الصف الذي سيصير‎ 
الصف الحالي.. كل ما سنفعله هو إنعاش كلا الصفين باستدعاء الوسيلة‎ 
التي تستقبل رقم الصف المراد‎ 101771677. 11012610777 
الغا ر سه هذا هو كود هذا الحدف:‎ 
Dim LastRow = 2011011716311.) 11111140777 
If LastRow IsNot Nothing Then 
DataGridView1.InvalidateRow(LastRow.Index) 
End If 
DataGridView1.InvalidateRow(e.RowIndex) 
يمكنك الآن تجربة الكود.. ستجده يعمل على ما يرام.‎ 
لكن تتبقى مشكلة واحدة فقط» تحدث عند تحريك المنزلق الأفقي (إن كان‎ 
ظاهرا)ء فهذا يؤدي إلى تكرار رسم الإطارء ما يجعل الحافة اليسرى له ترسم‎ 
أكثر من مرة داخل خانات الصف مع استمرار التحرك.. نحتاج إذن إلى‎ 
إنعاش المستطيل كلما تحرك المنزلق الأفقي.. يمكن فعل هذا في الحدث‎ 
كالتالي:‎ DataGrid View.Scroll 
If e.ScrollOrientation = ScrollOrientation.HorizontalScroll _ 
AndAlso DataGridView1.CurrentRow IsNot Nothing Then 
DataGrid View1.InvalidateRovw( 
DataGridView1.CurrentRow.Index) 
End If 
لاحظ أن الطريقة التى استخدمناها لمعرفة ظهور المنزلق الرأسى فيها مشكلةء‎ 
فهي لا تأخذ في الاعتبار مساحة المنزلق الأفقي إن كان ظاهرا.. في الحقيقة‎ 


آنا أستخدم طريقة مختلفة»ء فقد أنشأت أداة جديدة ترث الأداة 
7177 ووهذا أتاح لي استخدام الوسائل والخصائص المحمية 
Protected‏ في فئة جدول العرضء ومنه االخاصية 
11 215 17177.17 التي تعيد كائن المنزلق الر أسيء 
ومن خلاله يمكن استخدام الخاصية »1715161 لمعرفة إن كان ظاهرا أم لاء 
كما يمكن استخدام الخاصية )17/710 لمعرفة عرضه. 


#۶ إضافة صفوف 0060 1201054: 

ينطلق عند إضافة صفوف جديدة إلى جدول العرض برمجياء أو بواسطة 
الفستخدم (عندما يكتب فى الصف الجديد الموجوذ فى نهاية الجدول), 

ويمكتك استخدام هذا الخدت لر تيب الصقوت المضحافة؛ وذلك باقعا 
الوسيلة 501 الخاصة بجدول العرض.. والمعامل الثاني ع لهذا الحدث من 
النوع ›DataG ri ViewRowsAddedEventArgs‏ وهو يمتلك الخاصيتين 
التاليتين: 

5 به | 2071006 | تعيد رقم أول صف من الصفوف التي أضيفت إلى 
الجدول. 

و | 110100104 | تعيد عدد الصفوف التي أضيفت إلى الجدول. 














۶ إضافة صف بواسطة المستخدم ::1561240060120]: 
ينطلق عندما يضيف المستخدم صفا جديدا إلى جدول العرض. 


© حذف صفوف :Rows Removed‏ 
الثاني ع الخاص به من النوع DataGridViewRowsRemovedEventArgs‏ 
وهو : i‏ الخا يتين التاليتين: 

و | 12071006 | تعيد رقم أول صف من الصفوف التي حذفت من 
الجدول. 

5 بور | 18070001114 | تعيد عدد الصفوف التي حذفت من الجدول. 














۶ المستخدم يحذف صفا :UserDeletingRow‏ 
ينطلق عندما يحاول المستخدم حذف صف» وقبل أن يتم حذف الصف فعلياء 
ليتيح لك عرض رسالة تحذير للمستخدم أو إلغاء عملية الحذف.. والمعامل 
الثاني ع لهذا الحدث من نوع الفئة «DataGridViewRowCancelEventArgs‏ 




















وهي ترث الفئة وع1)مء032061557» مما يعني أنك تستطيع وضع القيمة 
م" في الخاصية 1[ع020.ء لإلغاء حذف الصف.. كما يملك هذا المعامل 
الخاصية س0 ۸.ء التي تعيد كائن الصف 133011017161120 الذي يريد 
المستخدم حذفه.. وقد فعلنا هذا في المشروع DataGridViewAuthorBooks‏ 
بالكود التالي: 

1 ,"هل تريد حذف هذا الصف"):111155130 

MsgBoxStyle.OkCancel) = MsgBoxResult.Cancel Then 
e.Cancel = True 
End If 

كما استخدمنا هذا الحدث في المشروع 10313561]5811016.. في هذا 
المشروع لو حذف المستخدم أحد المؤلفين من الجدول العلوي» فإن كتب هذا 
المؤلف ستظل في جدول الكتب» ولو حاول حفظ التغييرات في قاعدة البيانات 
فسيتم رفض ها بس بب قي د المفقاح الفر عي 
۴ore1gn Key Constraint‏ المفروض على العلاقة بين المؤلفين وكتبهم» 
والتي تمنع وجود كتاب مرتبط بمؤلف تم حذفه! 
ويمكنك حل هذه المشكلة على مستوى قاعدة البيانات أو مجموعة البيانات» 
تخبط خصاتصن الق لحف السحلات الف عة تتابعيا بمهره حذف المكك 
الأصلي Delete‏ ©0356306.. لكننا استخدمنا حلا آخر في هذا المشروع»› 
وذلك باستخدام الحدث 10819017اء1ء(115611] الخاص بجدول عرض 
المؤلفين» لحذف السجلات المعروضة حاليا في جدول عرض الكتب. 


# المستخدم حذف صفا 1719611(61666012037: 

ينطلق بعد حذف المستخدم لأحد صفوف جدول العرض.. لاحظ أن الحدث 
1 ينطلق أولا قبل انطلاق هذا الحدث» بسبب انتقال المؤشر إلى 
المواقف.. مثلا: لا يمكنك استخدام هذا الحدث بدلا من الحدث 
181077 في المشروع 103435615812016 وذلك لأن حذف 
المؤلف يجعل المؤشر ينتقل إلى مؤلف آخر فينطلق الحدث ۴)۲ R0wء‏ 
الذي يعرض كتب المؤلف الحالي في جدول عرض الكتب» ثم ينطلق الحدث 
601077 فيحذف كتب مؤلف موجود» ولا يحذف كتب المؤلف 
المحذوف!.. لهذا تذكر دائما أن ترتيب انطلاق هذه الأحداث هو: 

.UserDeletedRow 'ڵ-‎ .RowEnter -'" .UserDeletingRow -١ 


۶ دخول الصف :RowEnter‏ 

ينطلق عند استقبال أحد صفوف جدول العرض للمؤشر وںءه۴؛ لكن قبل أن 
يصير هو الصف الحالي ..Current Row‏ والمعامل الثاني م لهذا الحدث 
من النوع DataGrid ViewO]el]EventArgs‏ وهو يمتلك الخاصيتين 
التاليتين: 

9 بون | 25071006 | تعيد رقم الصف الذي استقبل المؤشر. 

9 يور | 07 12مدصن1ه00) | تعيد رقم العمود الذي استقبل المؤشر. 


وقد استخدمنا هذا الحدث في المشروع 15نهاء112ع]10312011017/161/125.. 
في هذا المشروع وضعنا على النموذج جدولي عرضء أحدهما يعرض جدول 
المؤلفين» والثاني يعرض سجلات الكتب التابعة للمؤلف المحدد حاليا في 
جدول العرض الأولء كما في الصورة: 
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ولكى نفعل هذاء اتبعنا الخطوات التالية: 
-١‏ استخدمنا الحدث م۴ س٠۸‏ لمعرفة الصف الذي تم تحديده: 
Dim R = DGAuthors.Rows(e.RowIndex)‏ 
؟"- استخدمنا الخاصية DataGrid ViewRow.DataBoundItem‏ لنحصل 
على كائن عرض الصف 12343180717167 المناظر له في جدول 
المؤلفين: 
Dim DRv = CType(R.DataBoundItem, DataRowView)‏ 
If DRv Is Nothing Then Exit Sub‏ 
۳- استخدمنا الوسيلة DataRowْView.CreateChild View‏ لإنشاء كائن 
عرض :1034817167 يحتوي على سجلات الكتب التابعة لسجل هذا 
المؤلف.. لاحظ أن اسم العلاقة في هذا المشروع بالاسم "كتب المؤلف": 
("كتب |أئnمؤlئف'(View Dim Dv = DRv.CreateChild‏ 























- استخدمنا كائن العرض 10313177167 كمصدر بيانات لجدول العرض 
الثاني» وبهذا يعرض كتب المؤلف المحدد في جدول العرض الأول: 
DGAuthorBooks.DataSource = Dv‏ 
وستجد هذا الكود كاملا في المشروع .DataGridViewMasterDetails‏ 
وهناك مشروع آخر يعرض المؤلفين وكتبهم بنفس الطريقة» وهو المشروع 
1م550 لكن الكود الموجود في الحدث ۲٥ا۴ R 0w‏ في هذا 
المشروع مختلف قليلاء فهو يعتمد على أن رقم الصف في جدول العرض» هو 
نفس رقم الصف في كائن العرض الافتراضي 10618101597165 لجدو و 
المؤلفين» لهذا يحصل على كائن عرض الصف كالتالي: 
Dim TbIAuthors = Ds.Tables('Authors")‏ 
Dim DRv = TblAuthors.DefaultView(e.RowIndex)‏ 
وبعد هذا لا يوجد اختلاف في الكود» فهو يحصل على كائن عرض كتب 
المؤلف» ويستخدمه كمصدر بيانات لجدول عرض الكتب: 
Dim Dv = DRv.CreateChildView('AuthorsBooks'"")‏ 
DgBooks.DataSource = Dv‏ 
ELC‏ تغيير الترتيب يغير رقم كل 
صف في مجموعة الصفوف.. السبب في عدم کوت أية مشاكل» أن ترتيب 
جدول العرض يؤدي إلى ترتيب كائن العرض الافتراضي 10612111497165 
الخاص بجدول المؤلفين» مما يحافظ على نفس ترقيم الصفوف في كل من 
جدول العرض وكائن العرضء وبالتالي يعمل الكود بشكل صحيح دائما. 


۶۶ مغادرة الصف :R‌ow Leave‏ 
ينطلق عندما يفقد أحد صفوف العرض المؤشرء بسبب الانتقال إلى صف 
آخرء أو بسبب الانتقال من جدول العرض إلى أداة أخرى!.. والمعامل الثاني 
م لهذا الحدث من النوع DataGrid ViewC e11٤ ven) Ags‏ كما في الحدث 

السابق. 


2 إجازة الصف :RowValidating‏ 
ينطلق عندما يحاول المستخدم مغادرة الصف الحالي في جدول العرض.. هذا 
يتيح لك فحص القيم التي أدخلها في هذا الصف والتأكد من صحتها. 
والمعامل الثاني م لهذا الحدث من نوع الفققفة 
«DataGridViewCellCancelEventArgs‏ وهي ترد الفئفة 
»Cance]Event Ars‏ مما يعني أنك تستطيع وضع القيمة 106 في 
الخاصية [عءمه٣.ء‏ لإجبار المؤشر على البقاء في الصف الحالي» وذلك 


Î 


عندما تكتشف أن به قيمة خاطئة وتريد إجبار المستخدم على تصحيحها أولا.. 
كمايمئلك ه ذ المعاعم ل الخاصصيتين 6120597120676 
و 120672مدطن1ه00.ع كما في الحدث رمم :101]. 


۶ تمت إجازة الصف :RowValidated‏ 
ينطلق بعد إجازة بيانات الصف الحالي في جدول العرض.. لاحظ أن مغادرة 
المستخمه الت الخال زوذي إلى الطلاق الأحداث الثالية بالترقيب: 
-١‏ الحدث نرهع)م:[ ون ]1 الخاص بالصف الذي فقد المؤشر. . في الحقيقة هذا 
أمر عجيب وغير مبررء لكنه يحدث! 
-١‏ الحدث عتهع120171 الخاص بالصف الذي فقد المؤشر. 
۳- الحدث ع 7721100 الخاص بالصف الذي فقد المؤشر. 
- الحدث 177311013660 الخاص بالصف الذي فقد المؤشر 
-٥‏ الحدث :زع ]120710 الخاص بالصف الجديد الذي استقبل المؤشر. 


إلغاء مشاركة الصف :RowUnshared‏ 
ينطلق عندما يتحول صف مشترك 120187 583160 إلى صف غير مشترك 
..nshared Row‏ ويمكنك استخدام هذا الحدث أثناء اختبار أداء برنامجك»› 
لمعرفة الكود الذي يسيب كي جعل الصغوف تقنة بخاضية المتناركة .. هذا مفيد 
عندما تريد توفير الذاكرة في البرامج التي تعرض كما هائلا من البيانات في 
جدول العرض 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


له 


التعامل مع خانات جدول عرض البيانات: 
يمنحك جدول العرض الخصائص التالية للتعامل مع خاناته: 


37 العنصر «رع)1: 
هذه هي الخاصية الافتراضية لجدول العرض» وهي تعيد كائن الخانة 
11716011 الموجودة في العمود المرسل كمعامل أول» والصف 
الفوسل كمعاسل تان الل الال رض كم الا الم ك في الود 

الثاني والصف الثالث: 1 1 

MsgBox(DataGridView1(1, 2).V alue) 
كنا جد ص أكرى» يك أن ترسل الى معاطينا الأول انيم العصود بدلا‎ 

من رقمه» مثل: 
MsgBox(DataGridView1(" Author'"", 2).Value)‏ 


“5 الخانة الحالية :CurrentCell‏ 

تعيد كائن الخانة 11ع1(313001101/16500 المحددة حاليا في جدول العرض.. 
ويمكنك أيضا أن تضع في هذه الخاصية كائن الخانة التي تريد تحديدهاء حيث 
سينزلق جدول العرض لجعلها ظاهرة على الشاشة. . 

لاحظ أنك لا تستطيع أن تضع في هذه الخاصية خانة راس الصف 32061ع11 
أو خانة معطلة 1(1536160 أو خانة موجودة في صف مختفي 7ع811010» وإلا 
وتعيد هذه الخاصية عمنطاه" إن لم تكن هناك خانة محددة حالياء ولو 
وضعت Nothing ld‏ فسيزول مربع التحديد من الخانة الحالية. 


7 فع عنوان الخانة الحالية :CurrentCellAddress‏ 
تعيد كائن نقطة ازم" يحتوي على موضع الخانة الحالية» حيث تمثل 
الخاصية × رقم الصف الذي توجد به الخانةء والخاصية ۷ رقم العمود: 
رقم الصف الحالي ' MsgBox(Dgv.CurrentCel|Address.X)‏ 
رقم العمود الحالي ' MsgBox(Dgv.CurrentCel|Address.Y)‏ 


57 فل هل الخانة الحالية في وضع التحرير :IsCurrentCellI[n EditMode‏ 
تيد فو إذا كانت الحانة الحالية قي رضم التحرير خالا 


°۱١ 


ال طريقة التحرير ع1:01071006: 
تحدد كيف يمكن للمستخدم بدء تحرير الخانة» وهي تأخذ إحدى قيم المرقم 
©1100 اااالسلتالية: 


211511 اتتتحرير الخانة بمجرد دخولها.. هذا مفيد عند التنقل 
بين خانات الصف بضغط زر الجدولة 21/433 أو 
التنقل بين خانات العمود بضغط الزر *1هع1مآ. 
©3501 | تحرير الخانة عند ضغط أي حرف أبجدي. 

EditOn‏ تحرير الخانة عند ضغط حرف أبجدي أو الزر 

Keystroke2‏ 2" .. هذه هي القيمة الافتراضية. 
EditOnF2‏ تحرير الخانة عند ضغط الزر ۴2. 

.BeginEdit Programmatically 











لاحظ أن كل القيم السابقة ما عدا EditProgrammatically‏ تسمح للمستخدم 
ببدء تحرير الخانة بمجرد نقرها مرتين بالفارة. 


“57 فز أداة التحرير :EditingControl‏ 
تعيد كائن الأداة 0001 الذي يحمل أداة التحرير المستضافة في الخانة 
الحالية» إن كانت في وضع التحرير.. وإذا لم تكن الخانة الحالية في وضع 
التحري» تعيد هذه الخاصية عمنطاهN.‏ 


57 ف لوحة التحرير :Editing Panel‏ 
تعيد كائن اللوحة 7361 التي تستخدم لعرض أداة التحرير في الخانة الحالية.. 
ولهذه الخاصية قيمة دائما حتى لو لم تكن الخانة في وضع التحرير. 

7 فز هل الخانة الحالية قذرة :IsCurrentCel[Dirty‏ 


تعد ونون[ ا كانت ف اتخات الخ قد كرتر ل وق حف ار في 


o1۲ 




















7 أول خانة معروضة :FirstDisplayedCel1‏ 
تعيد كائن الخانة 611 172430110571610 الذي يمثل أول خانة عادية (ليست 
رأس صف أو عمود) ظاهرة على الشاشة في جدول العرض.. هذه الخانة 
تكون أعلى يسار الجدول المعروض من اليسار إلى اليمين» وأعلى يمين 
الجدول المعروض من اليمين إلى اليسار.. ويمكنك ايضا أن تضع في هذه 
الخاصية ا الخادة التي تريد أن يز لىخدول العرضن الها بجعا آرل 
خانة معروضة فيه. ٠‏ 


وعا الخانة العلوية اليسرى :TopLeftHeaderCell‏ 
تقرأ أو تغير كائن الخانة الرئيسية DataGrid ViewHeaderCe11‏ الذي 
يمثل الخانة الموجودة في الركن العلوي الأيسر من جدول العرض المعروض 
من اليسار إلى اليمين» أو الموجودة في الركن العلوي الأيمن في الجدول 
المعروض من اليمين إلى اليسار.. ويمكنك الاستفادة من هذه الخاصية في 
التحكم في خصائص هذه الخانةء ككتابة نص بهاء أو وضع قامة موضعية 
لها... إلخ. 


7 فز الخانات المحددة :SelectedCells‏ 
تعيد مجموعة من النوع «DataGridViewSelectedCe11Co1lection‏ 
التي ترث الفئة 83560001161101 وتمثل الواجهة 11.156» وهي تحتوي على 
الخانات المحددة حاليا في جدول العرض. 


و ا عرض أخطاء الخانات :ShowCelIErrors‏ 
إذا جعلت قيمة هذه الخاصية م1٠‏ فستعرض الخانات التي بها أخطاء أيقونة 


عرض تلميحات الخانات :ShowCe|| 1001 ¡ ps‏ 
إذا شت تا هذه القاضية و فسيطير سے طلى ا ا يملق 
المستخدم بالفأرة فوق أي خانة من خانات الجدول.. لاحظ أن هذا التلميح هو 
النص الموجود في الخاصية )بره 1م1 1٠٥11‏ الخاصة بالخانة. 


8 طريقة النسخ إلى لوحة القصاصات :Clipboard Copy Mode‏ 


تتحكم في كيفية نسخ الخانات المحددة إلى لوحة القصاصات» وهي تأخذ إحدى 
قيم المرقم DataGrid ViewClipboardCopyMode‏ التالية: 


o1۳ 








Disable 


Enable With 
AutoHeaderText 


EnableWithout 
HeaderText 
EnableAlways 
IncludeHeaderText 


القصاصات. 

يتم نسخ محتو يات الخانات المحددة» وان كانت 
هناك رؤوس أعمدة أو رؤوس صفوف محددة 
يتم نسخ محتوياتها أيضا. 

يتم نسخ محتويات الخانات المحددة فقط مع 
تجاهل رؤوس الصفوف والأعمدة. 

يتم نسخ محتويات الخانات المحددة ونسخ 
رؤوس الاعمدة ورؤوس الصفوف التي توجد 
فيها هذه الخانات» بغض النظر عما إذا كانت 
هذه الرؤوس محددة أم لا. 





وخ طراز حواف الخانات :CelIBorderStyle‏ 


تحدد شكل إطار خانات الجدول» وهي تأخذ إحدى قيم المرقم 
110 اسلتالية: 


None 
Single 
Single Vertical 
Single Horizontal 
Sunken 
SunkenVertical 
SunkenHorizontal 
Raised 
RaisedVertical 
RaisedHorizontal 
Custom 





لا توجد إطارات. 

إطار يتكون من خط مفرد. 

حافة راسية تتكون من خط مفرد. 

حافة أفقية تتكون من خط مفرد. 

إطار غائر. 

حافة رأسية غائرة. 

حافة أفقية غائرة. 

إطار بارز. 

حافة رأسية بارزة. 

حافة أفقية بارزة. 

إظار مخخص ص ذه القية الكراة قط ا 
يمكنك وضعها بنفسك» وإنما تتغير تلقائيا عند 
تغيير الخاصية ع5671ع1158010ع 4057320600 . 


© ف الطراز المتقدم لحواف الخانات :AdvancedCelIBorderStyle‏ 


تعيد كائن الطراز المتقدم DataGridViewAdvancedBorderStyle‏ 
الذي يتحكم في شكل إطار خانات جدول العرض. 


وخ الطراز الافتراضي للخانات :DefaultCel1IStyle‏ 


o14 



























































تقرأ أو تغير كائن طراز الخانة ع61156/1 131306110171650 الذي يتحكم 
في مظهز خانات الجدول. 


كما يمدك جدول العرض بالوسائل التالية للتعامل مع الخانات: 


ب 


ب 


تحديد الكل [4[1)ء»©561: 
تحدد كل خانات جدول العرض. 


هل جميع الخانات محددة :AreAIICellsSelected‏ 

تعيد 106 إذا كانت جميع خانات جدول العرض محددة» وهي تستقبل معاملا 
منطقياء إذا جعلته ع1:315 فسيتم فحص الخانات المرئية 116 فقطء أما إذا 
جعلته ع1[” فستدخل الخانات الخفية في الاعتبار. 


إزالة التحديد :ClearSelection‏ 
لجع كن aS‏ رضي ا 


تستقبل المعاملات التالية: 
- رقم العمود الذي توجد به الخانة المستثناة. 
- رقم الصف الذي توجد به الخانة المستثناة. 
- معامل منطقي» « إذ ا جعلته ووم ] a LS‏ الكاذة A‏ إن لم تكن 
محددة فعلاء وإذا جعلته 1/156 فستترك الخانة على حالتها الأصلية 
كما كانت» سواء كانت محددة أم لا. 
وقد استخدمنا هذه الخاصية في الزر "تحديد الصف الثاني" في المشروع 
55 لاإزالة تحديد كل الخانات قبل تحديد 
الصف الثاني كالتالي: 
DGAuthors.ClearSelection( )‏ 
DGAuthors.Rows(0).Selected = True‏ 
لاحظ أن هذا الكود أكفأ من كود الزر "تحديد الصف الأول" في نفس 
المشروع» ليس فقط لأنه أكثر اختصارا وسهولةء ولكن لأن إزالة تحديد 
الصفوف المحددة لا يزيل تحديد الخانات المتفرقة المحددة.. جرب أن تضغط 
الزر .0111 وتضغط أكثر من خانة متفرقة بالفأرة.. لو ضغطت الزر 
"تحديد الصف الأول" فسيحدد الصف الأول دون إزالة تحديد هذه الخانات» 
بينما لو ضغطت الزر الثاني» فسيزيل تحديد جميع هذه الخانات ويحدد الصف 
الثانى. 


7# الحصول على محتوى لوحة القصاصات :GetClipboardContent‏ 


هاه 


او 


تعيد كائن بيانات Dat bjet‏ يحتوي على الخانات المحددة حاليا في 
جدول العرض» ليمكنك وضعه فى لوحة القصاصات مباشرة دون أن تشغل 
ذهنك بنسخ محتويات الخانات بتنسيق خاص بك.. ولقد شرحنا كائن البيانات 
hata bjet‏ بالتفصيل عندما تعرفنا على لوحة القصاصات Clipboard‏ 
في كتاب "برمجة نماذج الويندوز". 

وتسبب هذه اوسا لطا تشب انات إذا كانت للخاصية 
21100 القيمة .Disable‏ 

وما لم تكن في حاجة إلى برمجة أوامر النسخ واللصق الخاصة بك في قائمة 
رئيسية أو موضعية»ء فلن تحتاج إلى استدعاء هذه الوسيلة بنفسك» فبمجرد 
ضغط المستخدم +1) من لوحة المفاتيح يتم نسخ الخانات المحددة في 
جدول العرض إلى لوحة القصاصات تلقائياء حيث يمكنك لصقها في أي 
برنامج آخر.. على سبيل المثال: عند لصق الخانات في برنامج 7101:6720 
يوضع حرف جدولة (أربع مسافات) بين محتوى كل خانة والتي تليهاء 
ويوضع كل صف في سطر جديد. . أما عند لصق هذه الخانات المنسوخة في 
برنامج ۰0۲4 فإنه يعرضها في شكل جدول. 


معرفة عدد الخانات :GetCelICount‏ 
تعيد عدد خانات جدول العرض التي لها الحالة المرسلة كمعامل» وهي تستقبل 
إحدى قيم المرقم ءع†a۾†ViewEl]lementS hata Grid‏ التي تعرفنا عليها من 


معرفة مستطيل عرض الخانة :GetCelIDisplay Rectangle‏ 

تعيد كائن المستطيل ماعمهاءه۸ الذي يحتوي على موضع وأبعاد الخانة 

المطلوبيق وهى تستقيل المعاملات التالية: 

- رقم العمود الذي توجد به الخانة. 

> مرق الضيف الأن تريية ف الكاةة. 

9 معامل منطقي إذا جعلته 116 فسيحتوي المستطيل على أبعاد الجزء 
الظاهر من الخانة على الشاشة» وإذا جعلته 10156 فسيحتوي المستطيل 
على أبعاذ القانة كلها 


كاه 


إبطال الخانة 1[[ع'12521102666: 

أرسل إلى هذه الوسيلة كائن الخانة 611 1234861105/160 التي تريد تعطيل 
رسمها لتجبر جدول العرض على إعادة رسمها من جديد. 

وتوجد صيغة أخرى من هذه الوسيلة تستقبل رقم العمود ورقم الصف اللذين 
توجد بهما الخانة بدلا من استقبال كائن الخانة. 


#ا> بدء التحرير :Begin Edit‏ 


تضع الخانة الحالية في وضع التحرير.. ولهذه الوسيلة معامل منطقي» إذا 
جعلته 106 فسيتم تحديد كل محتويات الخانة في أداة التحرير. 


إلغاء التحرير )226211501 ©: 
تلغي تحرير الخانة الحالية وتعيد الخانة إلى قيمته الأصلية.. وتعيد هذه الوسيلة 
True‏ إذا نجح إلغاء التحرير. 


:CommiE dit قبول التحرير‎ 2# 


تحفظ القيمة من أداة التحرير إلى الخانة الحالية» دون إنهاء وضع التحرير.. 
وهي تستقبل كمعامل إحدى فيم المرقم DataGridViewDataErrorContexts‏ 
التي توضح الخطأ الذي يمكن أن يحدث أثناء حفظ القيمة» وقد تعرفنا على هذا 
المرقم من قبل.. وتعيد هذه الوسيلة 116 إذا نجحت عملية الحفظ. 


:Refresh Edit إنعاش التحرير‎ ۳ 


تحدث القيمة التي لعرضها أداة التحريرء بإعادة قراءة القيمة من الخانة 
الحالية.. هذا مفيد عندما تتغير قيمة الخانة الحالية (نتيجة تغير مصدر 
البيانات) بينما يقوم المستخدم ب بتحرير الخانةء وتريد أنت تنبيهه إلى هذا 
التغيير.. وتعيد هذه الوسيلة 156 إذا نجح إنعاش أداة التحرير. 


إنهاء التحرير 1:2017016: 

تنهي تحرير الخانة الحالية وتحفظ القيمة الجديدة في الخانة الحاليةء وتعيد 
True‏ إذا نجح إنهاء التحرير. 

وتوجد صيغة أخرى لهذه الوسيلة» تستقبل كمعامل إحدى قيم المرقم 
5< التي توضح الخطأ الذي يمكن أن 
يحدث أثناء حفظ القيمة» وقد تعرفنا على هذا المرقم من قبل. 


/ااه 


1#- التنبيه بأن الخانة الحالية قذرة :NotifyCurrentCe1[Dirty‏ 

تنبه جدول العرض إن كانت الخانة الحالية قد حفظت التغييرات إلى مصدر 
البيانات أم لا.. وهي تستقبل معاملا منطقياء إذا جعلته م1۲ كان هذا معناه 
أن الخانة الحالية لم تحفظ التغييرات إلى مصدر البيانات. 
وعليك استخدام هذه الوسيلة إذا كنت تتعامل مع أنواع خانات خاصة بك.. لهذا 
استخدمناها في المشروع وعم2157:نن1[ 1233011000 في الحدث الدال على 
تغير محتويات أدوات التحرير الجديدة التي أنشأناها: 

- الحدث OnValueChanged‏ في الفئة .CalendarEditingControl‏ 

- والحدث OnTextChanged‏ في الفنتين TreeEditingContro]‏ 

.TreeComboEditingControl و‎ 


كما يمدك جدول العرض بالأحداث التالية للتعامل مع الخانات.. والمعامل الثاني م 
لمعظم هذه الأحداث من النوع DataGridViewCellEventHandler‏ الذي 
تعرفنا عليه سابقاء وهو يخبرك برقم الصف ورقم العمود الذي توجد به الخانة: 


2 تغير نص خطأ الخانة :CellErrorTextChanged‏ 
ينطلق عندما تتغير قيمة الخاصية ج'1 7:01 الخاصة بإحدى الخانات. 


۶۶ تغير حالة الخانة :CelIStateChanged‏ 
ينطلق عندما تتغير حالة إحدى خانات جدول العرضء كأن يوضع بها المؤشر 
الضوئي أو يزول منها.. والمعامل الثاني م لهذا الحدث من النوع 
901511360177 وهويمتلك 
الخاصيتين التاليتين: 

ين Cell‏ تعيد كائن الخانة 1021801101716100611 التي 
تغيرت حالتها. 

53 بو | أععمةط٣ء)هSt‏ | تخبرك بالحالة الجديدة للخانة» وهي تعيد إحدى 
قيم المرقم DataGridViewElementStates‏ 
الذي تعرفنا عليه من قبل. 














۶ تغير الخانة الحالية :CurrentCelIChanged‏ 
ينطلق عندما تتغير الخانة المحددة حاليا في جدول العرض» بسبب تغير قيمة 
الخاصية 016140611 من الكودء أو بسبب انتقال المستخدم من الخانة 
الحالية إلى خانة أخرى. 


01۸ 











2 تغير قيمة الخانة :CellValueChanged‏ 
ينطلق عندما تتغير قيمة إحدى خانات جدول العرضء وذلك بعد انتهاء وضع 
التحرير.. ويمكنك استخدام هذا الحدث لاتخاذ رد الفعل المناسب بعد تغير قيمة 
الخانة» مثل فحص القيمة الجديدة للتأكد من صحتهاء أو إعادة ترتيب صفوف 
الجدول إذا كان الجدول مرتبا تبعا لخانات العمود الذي توجد به هذه الخانة. 


#2 تغير الحالة القذرة للخانة الحالية :CurrentCellDirtyStateChanged‏ 
ينطلق عندما تتغير قيمة الخانة بينما لا زالت في وضع التحرير ولم يتم حفظ 
قيمتها فعلا.. هذا مفيد في بعض الحالات» مثل الاستجابة لتغيير المستخدم 
لحالة مربع اختيار. 11301 موضوع في إحدى الخانات دون مغادرة 
الخانةء ففي هذه الحالة لن ينطلق الحدث عع مهط0ه0611772116.. وقد 
استخدمنا هذا الحدث في المشروع كعم DataG ri4 هاum 1y‏ لعرض 
رسالة تخبر المستخدم بحالة مربع الاختيار بمجرد تغييرهاء ودون حتى أن 
يغادر الخانة.. لفعل هذاء فعلنا ما يلي: 

- تأكدنا أولا أن الخانة الحالية في جدول العرض 010116110611 هي خانة 
مربع اختيار DataGrid ViewCheckBoxCe[[‏ لأن هذا الحدث 
ينطلق مع أي نوع من أنواع الخانات. 

- استخدمنا الخاصية ع u‏ ]2 1۷ء Edited ۴0 ۲na†)‏ الخاصة بالخانة الحالية 
لعرض قيمة مربع الاختيار للمستخدم.. ونظرا لأن هذه الخاصية تعيد 
كائنا 0 [01» فقد حولناه أولا إلى نوع المرقم 060151816 لنستطيع 
عرض اسم حالة الاختيار باستخدام الوسيلة ع105110: ولو لم تفعل 
ناء فسسسيتظين ارق ان تسسدل علس العاليية فتسيل 
دضدكي ا ظ 

- ستواجهنا مشكلة هناء وهى أن هذا الحدث ينطلق بعد أول مرة تتغير فيها 
حالة الخانة» ومهما وضع المستخدم علامة الاختيار أو أزالها فلن ينطلق 
هذا الحدثء إلا إذا غادر المستخدم الخانة الحالية أولا ليتم حفظ التغيير.. 
ولحل هذه المشكلة يمكننا أن نجبر الخانة على حفظ التغييرات باستخدام 
الوسيلة 001771611031 الخاصة بجدول العرض. 

- لكن استدعاء الوسيلة 00121711:016) سيؤدي إلى انطلاق الحدث 
2220 في الحال وقبل تنفيذ باقي 
الإجراء الحالي»› وهو ما سيجعل الرسالة تظهر مرتين. . ولحل هذه 
المشكلة» عرفنا متغير منطقيا عإVariab‏ 2001632 اسمه 
2ع واس تخدمناه كمؤثثئر 
8 بحيث نجعل قيمته ع1:]' قبل استدعاء الوسيلة CommitEdit‏ 
ونعيدها إلى عوإه۴ بعدها مباشرة» وفي بداية الحدث 


4ه 


ع6 نفحص قيمة هذا المتغير» فإن 
كات ونآ نخاس الإجراء في الهالى, ويهذا نظون الرسائلة مر واحدة 
وستجد هذا الكود كاملا في المشروع Types‏ مططنآ1ه103180110000. 


#۶ بدء تحرير الخانة :CellBegin Edit‏ 
ينطلق عند بدء تحرير إحدى خانات جدول العرض. . والمعامل الثاني م لهذا 
الحدث من gill‏ ع DataGrid ViewCelICance1EventArgs‏ الذي تعرفنا 
عليه من قبل» وهو يتيح لك إلغاء عملية التحرير بوضع القيمة 1506 في 
الخاصية [ععمه0).ع. 


۶ ظهور أداة التحرير :EditingContro1IShowing‏ 
ينطلق عند بدء تحرير الخانة الحالية في جدول العرضء وظهور أداة التحرير 
بها . والمعامل الثاني م لهذا الحدث من التوع 
›DataG rid ViewEditingControl]ShowingEventArgs‏ وهو يمتلك 
الخاصيتين التاليتين: 


0n tr1 E‏ | تعيد كائن الأداة 1م00 الذي يمثل أداة التحرير 
التي يتم عرضها حاليا.. ويمكنك تحويل هذا الكائن 
إلى نوع أداة التحرير الفعلي» واستخدامه لتغيير 
خصائصها أو وضع القيم الابتدائية بها. 

هد بي ١‏ 516 1آء0 | تعيد كان _ ص رز الخانة 
5151 الذي يمكنك من 
خلاله التحكم في شكل وتنسيق الخانة التي يتم 
تحريرها حاليا. 














ومن فوائد هذا الحدث» منحك القدرة على الاستجابة لأحداث أداة التحرير.. 
على سبيل المثال: إذا أردت أن تمنع المستخدم من كتابة أي شيء ما عدا 
الأرقام في خانات العمود رقم ١‏ في جدول العرض (افترض أن اسمه ,ج(12)» 
فيمكنك استخدام هذا الحدث لفعل هذا كالتالي: 
RemoveHandler e.Control.KeyPress,‏ 
AddressOf PhoneColumn_ KeyPress‏ 
If Dgv.CurrentCell.ColumnIndex = 1 AndAlso‏ 
e.Control IsNot Nothing Then‏ 
AddHandler e.Control.KeyPress,‏ 
AddressOf PhoneColumn_ KeyPress‏ 
End If‏ 


مه 











# 
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كل ما فعلناه هو إضافة معالج للحدث وو٥إ۴‏ رم الخاص بأداة التحرير 
(ستكون مربع نص في الأعمدة النصية).. لاحظ أن نفس الأداة قد تستخدم في 
تحرير أعمدة أخرىء لهذا قمنا بإزالة معالج الحدث في بداية الكود» حتى تعمل 
باقي الأعمدة بشكل طبيعي.. وحتى لو لم يكن لديك سوى عمود واحدء فعليك 
فعل نفس الأمرء لأن إضافة معالج للحدث KeyPress‏ في كل مرة تظهر فيها 
أداة التحريرء سيؤدي إلى تكرار انطلاق الحدث وو٥إ۴‏ رم عدة مرات» مما 
سيبطئ البرنامج بمرور الوقت! 
أخيرا: هذا هو كود الإجراء المعالج للحدث :KeyPress‏ 
Private Sub PhoneColumn KeyPress(sender As Object,‏ 
e As KeyPressEventArgs)‏ 
If Not Char.IsDigit(e.KeyChar) AndAlso‏ 
e.KeyChar <> Chr(Keys.Back) Then‏ 
Beep( )‏ 
e.Handled = True‏ 
End If‏ 
End Sub‏ 


إنهاء تحرير الخانة :CelIEnd Edit‏ 
ينطلق عند انتهاء تحرير الخانة الحالية في جدول العرض. 


ضغط الخانة ع[6»11011: 

ينطلق عند ضغط أي جزء من الخانة بزر الفأرة بما في ذلك إطارها وهامشها 
ومحتوياتها وأي أداة موضوعة داخلها.. وينطلق أيضا عند ضغط زر المسافة 
من لوحة المفاتيح عندما يكون بالخانة زر أو مربع اختيار. 


ضغط الخانة بالفأرة :CellMouseClick‏ 

مماثل للحدث السابق» ولكنه يتميز عنه بأن المعامل الثاني © من النوع 
ع1 1011110115 الذي تعرفنا عليه سابقاء وهو 
يعطيك معلومات وافية عن موضع الفأرة وحالة أزرارها. 


ضغط محتويات الخانة :CellContentClick‏ 

ينطلق عند ضغط الأداة التي تستضيفها الخانة.. وقد استخدمنا هذا الحدث في 
التطبيق 5و6م1111:2:157 103120011000 لعرض رسالة للمستخدم عندما يضغط 
زرا في أحد خانات عمود الأزرار» كما استخدمناه في المشروع 


o۱١ 


11170115 لعرض نافذة جديدة بها كتب المؤلف 
الذي م بضغط الزن الخاص هدر 


اع عانم 


تباي المهاذ 


فار رش “دہ 


E‏ اخ | عاب اشام 


| دعا 





۶ النقر المزدوج على الخانة :CelIDoub1eClick‏ 
ينطلق عند النقر مرتين بالفأرة على أي جزء من الخانةء بما في ذلك إطارها 
وهامشها ومحتوياتها وأي أداة موضوعة داخلها. 


۶ النقر المزدوج على الخانة بالفأرة :CellMouseDoub1eClick‏ 
ممائل لتسحث السا واكده يقير دة هان المعامل اااي ع فين الشبووع 
Gr ViewCe]MouseEventArgs‏ الذي تعرفنا عليه سابقاء وهو 
د يعطيك معلومات وافية عن موضع الفأرة وحالة أزرارها. 


۶ النقر المزدوج على محتويات الخانة :CellContentDoub1eClick‏ 
ينطلق عند النقر مرتين بالفأرة على الأداة التي تستضيفها الخانة. 

#2 هبوط زر الفأرة فوق الخانة :CellMouseDown‏ 
يحدث مباشرة بعد ضغط المستخدم لأحد أزرار الفأرة» بينما مؤشرها فوق 
الخانة» وقبل أن يترك الزر.. والمعامل الثاني ع من النوع 
.DataGridViewCellMouseEventArgs‏ 


ارتفاع زر الفأرة فوق الخانة :CelIMouseUp‏ 
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ينطلق بعد ترك المستخدم لزر الفأرة المضغوطء ومؤشرها فوق الخانة.. 
والمعامل الثاني ع من النوع .DataGridViewCellMouseEventArgs‏ 


دخول الفأرة إلى الخانة :CellMouse Enter‏ 
ينطلق عندما يدخل مؤشر الفأرة إلى حدود الخانة» وينطلق لمرة واحدة فقط 
إلى أن يغادر المؤشر حدود الخانة. 


مغادرة الفارة للخانة :CellMouse Leave‏ 
ينطلق عندما يغادر مؤشر الفأرة حدود الخانة. 


تحرك الفأرة فوق الخانة :CellMouse Move‏ 

ينطلق أثناء تحرك مؤشر الفأرة فوق الخانة.. والمعامل الثاني ممن النوع 
و تخغادء 15 111/]0115ء 122011017160 وهو ينطلق عدة مرات في 
كل ثانية إلى أن يتوقف المؤشر عن الحركة» أو يغادر حدود الخانة. 

دخول الخانة :CelIEnter‏ 

وطق عد عير الخاننة الكالية فلن دول العوض بالانقال إلى خا 
أخرىء أو عندما ينتقل المؤشر الضوئي من أداة أخرى إلى جدول العرض. 
ويمكن أن ينطلق هذا الحدث مرتين متتاليتين» وذلك إذا كان المؤشر الضوئي 
في أداة أخرى» وضغط المستخدم خانة غير الخانة التي كانت محددة في 
جدول العرض. 


مغادرة الخانة 61116256 ©: 
ينطلق عندما يغادر المستخدم الخانة الحالية في جدول العرضء وتفقد المؤشر 
الضوئي. 


تجري إجازة الخانة :CellValidating‏ 

ينطلق عندما يحاول المستخدم مغادرة الخانة الحالية.. والمعامل الثاني ع لهذا 
الحدث من نوع الفنة «DataGridViewCellValidating EventArgs‏ 
وهي ترث الفئة وع41)مء032061557)» مما يعني أنك تستطيع وضع القيمة 
م" في الخاصية 1ع0020).» لإجبار المؤشر على البقاء في الخانة الحاليةء 
وذلك عندما تكتشف أن بها قيمة خاطئة وتريد إجبار المستخدم على تصحيحها 
أولآى وإطبيافة إلى هذاه يمثلك هذا المعامل الخصبائصن الثالية: 


بور | ع0 2[سددطن[ه00). | تعيد رقم العمود الذي توجد به الخانة. 
RowIndex 1-E‏ تعيد رقم الصف الذي توجد به الخانة. 











o۲ 











2 ور | 0126601721116 | تعيد القيمة المنسقة الموجودة في الخانةء 
والتي عليك التأكد من صحتها. 














* تمت إجازة الخانة 611572110960 ©: 
ينطلق بعد التأكد من صحة القيمة الموجودة في الخانة. 


۶۶ تنسيق الخانة :CellFormatting‏ 

ينطلق عندما تحتاج الخانة إلى عرض قيمتهاء لتسمح لك بتنسيقها بالشكل الذي 
تريده.. ويمكنك استخدام الخاصية غهمم:ه115616.5ء122:2011017160 مباشرة 
لتحديد صيغة تنسيق الخانةء لكن أحيانا قد لا تجد صيغة مباشرة للتنسيق الذي 
تريده» وفي هذه الحالة يمكنك استخدام هذا الحدث لوضع القيمة بالشكل الذي 
تريده في الخانة.. كما أن هذا الحدث يتيح لك تغيير شكل الخانة وليس 
لاحظ أن هذا الحدث ينطلق كلما تم إنعاش رسم الخانة في الجدول» وكلما 
أردت قراءة قيمتها المنسقة.. هذا معناه أن هذا الحدث ينطلق كثيراء لهذا عليك 
ألا تكتب فيه أي كود طويل يستهلك وقتا ملموساء حتى لا تؤثر على سرعة 
وأداء البرنامج.. والمعامل الثاني م لههذا الحدث من النوع 
وع تخادء :لاع سناتدصدره 11 12380110171610» وهو يمتلك الخصائص التالية: 


۳ ×>ndeآumnاد)‏ | تعيد رقم العمود الذي توجد به الخانة. 
RowIndex 2‏ تعيد رقم الصف الذي توجد به الخانة. 
22 زور CellStyle‏ تقرأو تغير كائن طراز الخانة 
11571 الذي يتحكم في 
مظهرها وتنسيقها. 
2 ووس | Desired Type‏ | تعيد كائن النوع عم150» الذي يمثل نوع القيمة 
المنسقة المراد عرضها في الخانة. 
وج Value‏ تحتوي القيمة الأصلية للخانةء وعليك أن تضع بدلا 
منها القيمة المنسقة التي تريد عرضها. 
9 وو | Formatting‏ | إذا جعلت قيمتها ورم فستخبر الخانة بأن القيمة 
Applied‏ الموجودة في الخاصية "١721116‏ هي القيمة المنسقة» 
وعليها عرضها مباشرة بدون أي عمليات تنسيق 
إضافية... والقيمة الافتراضسية لهذه الخاصية هى 
«False‏ وهذا معناه أن علس الخانة استخدام 
خصيائضن الفسبيق الموجودة فل الخاضيتية 
.CellStyle‏ 
# تحويل قيمة الخانة :CelIParsing‏ 
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ينطلق بعد انتهاء تحرير قيمة الخانةء وذلك ليسمح لك بتحويل القيمة المنسقة 
التي أدخلها المستخدم إلى النوع الأصلي لبيانات الخانة.. هذا مفيد عندما 
تتعامل مع تنسيق خاص بك باستخدام الحدث السابق» وتريد إجراء عملية 
التحديث العكسية.. ولو لم تستخدم هذا الحدثء فستقوم الخانة بالتحويل التلقائي 
من النوع المنسق إلى النوع الأصلي.. والمعامل الثاني ع لهذا الحدث من 
النوع ›DataGridViewCellParsingEventArgs‏ وهو يمتلك الخصائص 
التالية: 


2 فون | :12016آنتسدن01") ١‏ تعيد رقم العمود الذي توجد به الخانة. 

| ×ملمآاسهR‏ | تعيد رقم الصف الذي توجد به الخانة. 
بيو | ed‏ eritطn]‏ تقرأأوتغيركائن طرز الخانة 
DataGrid ViewCel1Style | CellStyle‏ الذي يتحكم في 


ظهرها وتنسيقها. 

29 ون | e‏ مرآ Desired‏ | تعيد كائن النوع عم1587» الذي يمثل نوع القيمة 
الأصلية المراد التحويل إليها. 

Value‏ تحتوي القيمة المنسقة للخانة» وعليك أن تضع 


بدلا منها القيمة التي تريد حفظها في الخانة. 

2 ير Parsing‏ إذا جعلت قيمة هذه الخاصية عںإ1» فستخبر 
Applied‏ الخانة بأن القيمة الموجودة في الخاصية 
مuاه۷‏ هي القيمة الأصليةء وعليها حفظها 
مباشرة بدون أي عمليات تحويل إضافية.. 
والقيمة الافتراضية لهذه الخاصية هي ع1215» 
وهذا معناه أن على الخانة استخدام خصائص 
التنسيق الموجودة في الخاصية 
222115571 لتحويل القيمة المنسقة 
إلى القيمة الأصلية. 














2 رسم الخانة :CelIPainting‏ 
ينطلق عندما يحتاج جدول العرض إلى إعادة رسم إحدى خاناته.. والمعامل 
الثاني ع لهذا الحدث من النوع «DataGridViewCellPaintingEventArgs‏ 


2 ير 106 | تعيد رقم العمود الذي يحتوي على الخانة. 
9 وي ٠‏ 101206 تعيد رقم الصف الذي يحتوي على الخانة. 
E‏ 0115516 (أتعيد كان عرز الخانة 
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Advanced 
BorderStyle 


CellBounds 
Clip Bounds 


ErrorText 
Graphics 





551 الذي يتحكم 
في شكل وتنسيق الخانة المراد رسمها. 
تعيدك شن الصض رز المتققدم 
DataGridViewAdvancedBorderStyle‏ 
الذي يتحكم في شكل إطار الخانة. 

تعيد كائن المستطيل ءاعره† ء8 الذي يحمل 
موضع وأبعاد الخانة المراد رسمها. 

تقرأ أو تغير كائن المستطيل عاعمهاءع2 الذي 
يحمل موضع وأبعاد المساحة التي يجب إعادة 
رسمها من الخانة. 

تعيد نص الخطأ الخاص بالخانة. 

تعيد كائن الرسوم 1105م013 الذي سيستخدم 
لوميغ الخادة 


٦ 
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State 


Value 
Formatted 
Value 
PaintParts 


Handled 





تعيد إحدى قي الم رقم 
0 التي 
توضح حالة الخانة المراد رسمها. 

تعيد قيمة الخانة. 

PEEVE TE 


تحدد الأجزاء التي يجب على جدول العرض 
رسمها في الخانة» وهي تأخذ إحدى قيم المرقم 
.DataGridViewPaintParts‏ 

إذا جعلت قيمة هذه الخاصية مںإ] فستخبر 
جدول العرض بأن حدث الرسم قد تمت 
الاستجابة له كليا.. وعليك ألا تستخدم هذه 
القيمة إلا إذا أردت إلغاء رسم جدول العرض 
للخانة» وفى هذه الحالة عليك أن ترسمها أنت 
بنفسك من داخل هذا الحدث. 





كما يمتلك المعامل ع الوسائل التالية: 


# 








التعامل مع 


PaintContent | 4 


Paint 


Paint 
Background 





جدول العرض: 


ترسم جزءا من الخانة وهي تستقبل معاملين: 

- كائن المستطيل ماعمه)ءءR‏ الذي يحمل موضع 
وأبعاد المساحة التي سيعاد رسمها من الخانة. 

- إحدى قيم المرقم DataGrid ViewPaintParts‏ 
تد أجزاء الخانة الى يجبا رسسمها. 

ترسم خلفية الخانة» وهي تستقبل معاملين: 

- كائن المستطيل و[عمهء2 الذي يحتوي على 
موضع وأبعاد المساحة التي يراد رسم خلفيتها. 
المستطيل بلون خلفية التحديد «SelectionBackColor‏ 
وإذا جعلته ع17”015 فسيتم تلوين المستطيل بلون 
الخلفية .BackColor‏ 

ترسم محتويات الخانة وهي تستقبل کائن 

المستطيل عاع مج126 الذي يحتوي على موضع 

وأبعاد المساحة التى يراد رسمها.. لاحظ أن عليك 

رسم خلفية الخانة أولا قبل رسم محتوياتهاء ولو 

ف ا نوهو رويد الخلفية كوك الا 
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يمنحك جدول العرض الخصائص التالية للتحكم في مظهره وأدائه: 


و- لون الخلفية :BackgroundColor‏ 
تتحكم في لون خلفية جدول العرضء وهو اللون الظاهر في الجزء الذي لا 
توجد به خانات. 


3 طراز الحواف ٠ :BorderStyle‏ 
تحدد شكل إطار جدول العرض» وهي تأخذ إحدى قيم المرقم 280106156716 


None‏ جدول العرض بدون أي إطار. 
عاع51لع1" | يحيط بجدول العرض مستطيل أسود يتكون من خط مفرد 
السماكة. 
0 إإطار مجسم (ثلاثي الأبعاد). 











7 لون الشبكة :010 100: 
تتحكم في لون شبكة الخطوط التي تفصل بين ١‏ لصفوف والأعمدة.. وتؤثر هذه 
الخاصية فقط على الإطار المفردء لكنها تكون بلا تأثير عند استخدام إطارات 
مجسمة ففي هذه الحالة تستخدم الألوان الخاصة بنظام التشغيل. 


5 متعددة التحديد )16 311011015: 
إذا جعلت قيمة هذه الخاصية 736 (وهي القيمة الافتراضية)» فسيستطيع 
المستخدم تحديد أكثر من خانة أو صف أو عمود معا في نفس الوقت. 


و- للقراءة فقط 'و2060(2[1»ع12: 
إذا جعلت قيمة هذه الخاصية ع1[ . فلن يست يستطيع ١‏ 2 لمستخدم تحرير خانات 
جدول العرض.. والقيمة الافتراضية هي ع1215. 


ونج المنزلقات :Scrol[Bars‏ 
توضح أيا من المنزلقين سيعرضه جدول العرضء وهي تأخذ إحدى قيم المرقم 
cro]‏ التالية: 
None‏ الا تظهر أية منزلقات. 
210281 | المنزلق الأفقي فقط. 
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1 | المنزلق الرأسي فقط. 
61 |المنزلقين الأفقي والرأسي معا.. هذه هي القيمة الافتراضية. 


و- إزاحة الانزلاق الأفقي )1ع0115ع5 0111 “د 11011200215: 
تتحكم في الموضع المبدئي للمنزلق الأفقي.. والكود التالي يجعل المنزلق 
الأفقي يتحرك ليجعل العمود الثاني في الجدول أول عمود ظاهر على الشاشة: 
Dgv.HorizontalScrollingOffset = Dgv.Columns(0). Width‏ 


“5 ف إزاحة الانزلاق الرأسي :VerticaIScrolling Offset‏ 


وج طريقة التحديد :Selection Mode‏ 
تتحكم في طريقة تحديد خانات جدول العرض» وهي تأخذ إحدى قيم المرقم 
00 عه 15 اسلتالية: 


CellSelect 
FullRow 
Select 
FullColumn 
Select 


RowHeader 
Select 








يمكن تحديد خانة أو أكثر. 

يؤدي ضغط رأس الصف أو أية خانة موجودة به إلى 
تحذيد الضف كله 

يؤدي ضغط رأس العمود أو أية خانة موجودة به إلى 
تحديد العمود كله.. وتسبب هذه القيمة خطأ فى 
البرنامج إذا كانت للخاصية 50143810016 الخاصة 
بالعمود القيمة 11017211/. 

يؤدي ضغط رأس الصف إلى تحديد الصف كله»ء بينما 
يؤدي ضغط أي خانة إلى تحديد هذه الخانة بمفردها.. 
هذه هي القيمة الافتراضية. 


°۹ 



































ColumnHeader‏ | يؤدي ضغط رأس العمود إلى تحديد العمود كله»ء بينما 
Select‏ يؤدي ضغط أي خانة إلى تحديد هذه الخانة بمفردها.. 
وتسبب هذه القيمة خطأ في البرنامج إذا كانت للخاصية 
©0001 الخاصة بالعمود القيمة ©114011211الل. 
لاحظ أنك ستواجه مشكلة لو غيرت قيمة هذه الخاصية إلى 
ColumnHeaderSelect‏ أو أعن[ء 80110015 في وقت التصميم.. 
تعال نجرب هذا بأنفسنا: 
- ابدأ مشروعا جديدا اسمه .Selection Mode‏ 
- ضع على النموذج جدول عرض» واضغط ۳4 لعرض نافذة 
الك ان 
- اضغط الرابط صمصنآاه٣‏ ۸4 الموجود في الهامش السفلي لنافذة 
الخصائص.. سيفتح هذا نافذة إنشاء عمود جديد مباشرة.. غير 
خصائص العمود» واضغط )0 لإغلاق النافذة. 
- اضغط الرابط 00111115') 2:01 الموجود في الهامش ش السفلي لنافذة 
الخصائص» لفتح نافذة محرر مجمو عة الأعمدة. . غير قيمة ة الخاصية 
0 الخاصة بالعمود الذي أنشأته إلى 710150118616 حتى لا 
يحدث خطأ عند السماح بتحديد العمود كله» واضغط )0. 
- حدد الخاصية 5616002141006 في نافذة الخصائصء ومن القائمة 
المنسدلة اختر .ColumnHeaderSelect‏ 
- اضغط 775 لتشغيل البرنامج.. ستجد أن خطأ حدث في البرنامج منع 
عرض النموذج! 
لف مد سان م نينف متها اكد فت اكل ها هون لونم لمان هدك هذا 
الخطأ؟! 
السبب في هذاء يكمن في الكود الذي يحفظ قيم الخصائص التي تغيرها في 
وقت التصميم.. هذا الكود مكتوب في الملف طاv ›۴r01. Designer.‏ وهو 
مرتب بحيث يكتب خصائص جدول العرض أولاء تليها خصائص أعمدته.. 
هذا معنةه أن الخاصية SelectionMode‏ تتع ب سل أو لا ال 
umnHeaderSelectا0»‏ قبل أن تتغير الخاصية 501131006 الخاصة 
بالعمود ا ا هذا الخطأ.. ولا أنصحك بتغيير 
الكود الموجود في هذا الملف يدوياء لأن ما ستفعله سيضيع هباء عند أول 
تعديل تجريه على النموذج في وقت التصميمء لأنه سيؤدي إلى إعادة إنتاج 
كود ملف التصميم! 
لهذا ليس أمامك إلا حل واحد: أن تستخدم نافذة الخصائص لإعادة قيمة 
الخاصية Selection Mode‏ إلى ›RowHeaderSelect‏ وتستخدم حدث 
تحميل النموذج لتغيير قيمة هذه الخاصية كالتالي: 


OT 














DataGrid View1.SelectionMode =‏ 
DataGrid ViewSelectionMode.ColumnHeaderSelect‏ 
الآن لو شغلت البرنامج فسيعمل بشكل صحيح. وسيمكنك تحديد أي عمود 
بضغط ر أسه بالفأر 5 


وخ حرف الجدولة القياسي ا14 :S†4 "d4۲‏ 
إذا جعلت قيمة هذه الخاصية ‘True‏ فسيؤدي ضغط زر الجدولة 48 من 
لوحة المفاتيح إلى الانتقال من جدول العرض إلى الأداة التالية له على 
النموذج.. والقيمة الافتراضية لهذه الخاصية عو721: لهذا يؤدي ضغط زر 
الجدولة إلى الانتقال بين خانات جدول العرضء وفي هذه الحالة يمكن أن 
يضغط المستخدم 11+1۸8 للانتقال من جدول العرض إلى الأداة التالية له 
على النموذج. 


:UserSetCursor المؤشر المستخدم‎ Ei 
0012501 تعيد كائن مؤشر الفأرة 001801.. وهي تختلف عن الخاصية‎ 
الموروثة من الأداة الأم 1:01م00» في أنها تعيد قيمة مؤشر الفارة الأصليةء‎ 
مهما تغير شكل المؤشر نتيجة مروره فوق بعض المناطق الخاصة من جدول‎ 
العرض.‎ 


كما يمتلك جدول عرض البيانات الوسيلتين التاليتين: 


7# ترتيب )-م5: 
ترتب صفوف جدول العرض› ويمكنك استدعاءها في حدث ضغط رأس 
العمود umnHeaderMouseClickاد»‏ للتحكم في كيفية ترتيب 
الصفوف.. ولهذه الوسيلة صيغتان: 
-١‏ الصيغة الأولى تستقبل كائن واجهة المقارنة IComparer‏ الذي تريد 
استخدامه في عملية الترتيب (راجع كتاب برمجة إطار العمل). 
؟- والصيغة الثانية تستقبل معاملين: 
- كائن العمود 123120011017161)001111:1 الذي سيتم ترتيب الصفوف 
تبعا لقيم خاناته. 
- إحدى قيمتي المرقم 115150111011110 التي توضح إن كان 
الترتيب تصاعديا Ascending‏ أم تنازليا .Descending‏ 


# اختبار الضغط )و'11101: 
تخبرك بمعلومات عن موضع معين في جدول العرضء ولها معاملان: 


o۱ 


- الإحداثي الأفقي × للموضع. 

- الإحداثي الرأسي ۷ للموضع. 
وة هذه الوا كا مق وع فة اراك اش ار الف ع 
est]nf0اHitء‏ وهي فة معرفة داخل الفئة ›0a†a6 14V ¡1ew‏ تمتلك 


الخصضائض الثالية: 

Nowhere | jT 5 
Column E 

Index 

ColumnX E 
RowlIndex gj 
RowY بير‎ 2 
Type E 











E E E 
ري يشير إلى نقطة موجودة في‎ 10 
منطقة فارغة من جدول العرض (ليستا بها‎ 

خانات عادية أو خانات عناوين). 
تعيد رقم العمود الذي توجد فيه نقطة الاختبار. 


تعيد الموضع الأفقي لحافة العمود الذي توجد 

فيه نقطة الاختبار. 

تعيد رقم الصف الذي توجد فيه نقطة 

الاختبار. 

تعيد الموضع الرأسي لحافة الصف الذي توجد 

فيه نقطة الاختبار. 

تعيدإحدى قيم المه رقم 

DataGrid View.HitTestType‏ اتخبرك 

بقوع المقطقة التى ا يها نقطة الاكتبار + 

- مصN0:‏ منطقة فارغة. 

- [اءع0: خانة. 

- 01162061ن01©: رأس عمود. 

- 12011163061: رأس صف. 

- 1.61151630©1م10: الخانة الرئيسية العلوية 
اليسرى. 

:HorizontalSerol1Bar -‏ المنزلق الأفقي. 

:Vertica1Scro11Bar -‏ المنزلق الرأسي. 


وقد استخدمنا هذه الوسيلة في حدث حركة الفأرة 740115611076 الخاص 
بجدول العرض في المشروع 56160110201006 لنعرض في اللافقة 
110]ط] معلومات عن النقطة التي تتحرك فوقها الفارة. 

كما يمتلك جدول عرض البيانات الأحداث التالية: 


# اكتمال ربط البيانات ]ع1 دده')5 81013 12262: 


or 


























ينطلق بعد حدوث تغير في مصدر البيانات» أو بعد تغير قيمة أي من 
الخصائص التالية: : ..DataSource, DataMember, BindingContext‏ 
هذا مفيد عندما تريد أداء بعض المهام تناسب التغير الذي حدث في البيانات 
التي يعرضها جدول العرضء مثل تغيير عرض بعض الأعمدة وغير ذلك. 
والمعامل الثاني ممن النو ع ‘DataGridViewBindingCompleteEventArgs‏ 
وهو يملك الخاصية عم:015ععموط1.:5:0 التي تخبرك بنوع التغير الذي حدث 
في مصدر البيانات» وهي تعيد إحدى قيم المرقم عم/11505356015» التي 
تعرفنا عليها عند شرح الحدث 0عع1.15600آ.154.آع10لمز18 في فصل 
عروض البيانات 1/165 108128. 


2 خطأ في البيانات :DataError‏ 

ينطلق عند حدوث خطأ في مصدر البيانات» أو عند حدوث خطأ في تنسيق أو 
تحويل قيمة إحدى خانات الجدول.. والمعامل الثاني ع لهذا الحدث من نوع 
الففة »DataG rid ViewDataErrorEventArgs‏ وهي ترث الفئة 
Grid ViewCel]Cancel EventArgs‏ التي تعرفنا عليها سابقاء 
والتي تخبرك برقم العمود ورقم الصف اللذين توجد بهما الخانة التي سببت 
الخطأ.. وفي حالة حدوث الخطأ في مصدر البيانات الخارجيء فإن الخاصيتين 
110 و eR owndex‏ تخبرانك بموضع الخانة الحالية في 
جدول العرضء حتى لو لم تكن مسئولة عن الخطأ أو مرتبطة به بشكل 
مباشر.. كما يمكنك أيضا استخدام الخاصية 061م03).ه لإلغاء مغادرة الخانة 
التى سببت الخطأ لو كان الخطأ حدث بسبب تحرير إحدى الخانات. 

وإضافة إلى هذه الخضائصن الموروكة».يمتلك المعامل ج الخصائص الثالية: 


Context ٠‏ | تعيدإحدى قيم الرقم 
5< التي 
توضح سبب الخطأء وقد تعرفنا عليها سابقا. 














نفد 








a 
زا‎ 





Exception 


Throw 
Exception 








معلومات عن الخطأ الذي حدث. 

إذا جعلت قيمة هذه الخاصية 116» فسيتم إطلاق 
الخطأ في البرنامج بعد انتهاء تنفيذ كود الحدث 
الحالي.. والقيمة الافتراضية لهذه الخاصية هي 
.False‏ 





ويتصرف جدول العرض كالتالي إذا لم تكتب إجراء يستجيب لهذا الحدث: 

-١‏ عند مغادرة صف توجد أخطاء بإحدى خاناته» يعرض جدول العرض 
رسالة خطأ افتراضية للمستخدم فيها تفاصيل أكثر من اللازم عن 
الخطأء وهى رسالة قبيحة حقا ومنفرة! 

؟١-‏ يلغي القيم التي سببت الخطأء وينقل المؤشر إلى الصف الذي أراده 
المستخدم.. هذا مستفز جدا لأنه يزيل القيم التي أدخلها المستخدم ولو 
كان الخطأ في صف جديد فإنه يحذفه بالكامل! 

وللتخلص من هذا الأداء الشنيع» استخدم الكود التالي في هذا الحدث: 


هذا سيحقق لك فائدتين: 
-١‏ منع عرض رسالة الخطأ التلقائية» وتشغيل نغمة تحذير بدلا منها. 
؟- إجبار المستخدم على البقاء في نفس الصف دون إلغاء أي قيم أدخلهاء 


ف انزلاق 51011: 
ينطلق عندما يحرك المستخدم أحد المنزلقين.. والمعامل الثاني م لهذا الحدث 
من النوع وع501011157:0]41» وهو يمتلك الخصائص التالية: 


7 ييز 
7 ييز 
E‏ 





Old Value 
NewValue 
Scroll 
Orientation 





e.Cancel = True 
Beep( ) 


تعيد عددا يدل على موضع المنزلق قبل تحريكه. 
تعيد عددا يدل على موضع المنزلق بعد تحريكه. 
تعيد إحدى قيمتي المرقم ScrollOrientation‏ 
وهاتان القيمتان هما: 

- 1101120218151011: المنزلق الأفقي. 

- 1011 16215ع17: المنزلق الرأسي. 








ort 























E 








Type 





تعيد إحدى قيم المرقم 6م1157مء502011257:6 التي 

تخبرك بسبب انطلاق الحدث» وهذه القيم هي: 

:Sma] Decrement -‏ تم تحريك المنزلق خطوة 
صغيرة إلى الخلف. 

:SmallIncrement -‏ تم تحريك المنزلق خطوة 
صغيرة إلى الامام. 

- 016176101 13186106: تم تحريك المنزلق قفزة 
كبيرة إلى الخلف. 

:LargeIncrement -‏ تم تحريك المنزلق قفزة 
كبيرة إلى الأمام. 

:1humbPosition -‏ تم تحريك مؤشر الانزلاق 
إلى الأمام أو الخلف. 

- عاع13 طسناط1: يتم الآن تحريك مؤشر 
الانزلاق إلى الأمام أو الخلف. 

- 220151011 : توقفت عملية الانزلاق. 

:۴۲٤ -‏ وصل المنزلق إلى أقل قيمة له. 

- 1,354: وصل المنزلق إلى أقصى قيمة له. 





۶ تغير التحديد ا م ع 


بذ للة عندما 55 


تتغير الخانات أو الصفوف أو الأعمدة المحددة. 


مقارنة الترتيب :501:60012721: 
ينطلق عند مقارنة قيمتي خانتين في أحد الأعمدة أثناء عملية ترتيب الصفوف» 
وهو لا ينطلق إذا كان جدول العرض مرتبطا بمصدر بيانات» أو كان جدول 
العرض في الوضع الافتراضي 1/1110211/1006. 
والمعامل الثاني ع لهذا الحدث من النوع » وهو يمتلك الخصائص التالية: 


RRR Ê 








Column 


CellValue1 
CellValue2 
RowlIndex1 
RowIndex2 
SortResult 





تعيد كائن العمود DataGridViewColumn‏ 
الذي يتم ترتيبه. 

تعيد قيمة الخانة الأولى. 

تعيد قيمة الخانة الثانية. 

تعيد رقم الصف الذي توجد فيه الخانة الأولى. 
تعيد رقم الصف الذي توجد فيه الخانة الثانية. 

ضع في هذه الخاصية نتيجة المقارنة» وهي تأخذ 
ثلاث قيمة: 


oo 



































- عدد أصغر من الصفر إذا كانت الخانة الأولى 

-عدد أكيز من الضفر إذا كانت الخانة الثافية 
تسبق الأولى في الترتيب. 

:ضفرا ذا كانت الكالكان مساويكيخ. 

8332010 (اجعل قيمة هذه الخاصية عںإآ؛ إذا أردت ألا يقوم 

جدول العرض بأية عمليات مقارنة للخانتين بعد 

هذا 








ويسمح لك هذا الحدث بالتحكم في كيفية مقارنة خانات الجدول إذا كانت 
تحتوي على قيم مركبة تصعب مقارنتها مباشرة.. لكن لأهمية الفعلية لهذا 
الحدث تنبع من أنه يتيح لك الفرصة لترتيب صفوف الجدول تبعا لأكثر من 
عمود.. لكي تفعل هذاء اتبع الخوارزمية التالية: 


-١‏ قارن القيمتين 6111721161© و 61159721062©: فإن كانت إحداهما أكبر 
من الأخرى» فضع ناتج المقارنة في الخاصية 1[16ا501]1!651. 

؟- إذا كانت القيمتان CellValue1‏ و 0611977311162) متساويتين» فيمكنك 
استخدام عمود آخر للترتيب على أساسه؛ وليكن اسمه 012©. 

۳- استخدم الخاصيتين 120181206:1 و 1017120672 لقراءة قيمتي 
الخانتين الموجودتين في العمود 0012)»: وقارن بينهماء وضع ناتج 
المقارنة في الخاصية 501119©511[16. 

5 - إذا تساوت القيمتان من العمود 02012 أيضاء فيمكنك استخدام عمود ثالث 
للترتيب بنفس الطريقة» إذا كنت ترى هذا ملائما. 


والكود التالي يوضح لك هذه الخطوات: 


1ه 














If e.CellValue1.ToString < e.CellV alue2.ToString Then 
e.SortResult = -1 
ElseIf e.CellValue1.ToString > e.CellValue2.ToString Then 
e.SortResult = 1 
1/15» ' سنقارن خانتين من عمود آخر‎ 
Dim VI As String = DataGridView1("Col2", 
e.RowIndex1).Value.ToString( ) 
Dim V2 As String = DataGridView1("Col2", 
e.RowIndex2).Value.ToString( ) 
If V1 < V2 Then 
e.SortResult = -1 
Else 
e.SortResult = 1 
End If 
End If 
e.Handled = True 


# تم ترتيبه ع :S01‏ 
ينطلق بعد انتهاء ترتيب صفوف جدول العرض. 
اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 

آمين يا رب العالمين 


or 


التعامل مع جدول العرض في الوضع الافتراضي 7711:001211/1006: 

يتيح لك جدول العرض التحكم في عرض البيانات به بطريقتك الخاصةء وهو ما 
يعرف بالوضع الافتراضي مء ٠۷1۲٤141۷10‏ وهو مماثل للوضع الافتراضي 
الخاص بقائمة العرض 1,1567167 التي تعرفنا عليها في كتاب "برمجة نماذج 
الويندوز". 

وفي الوضع الافتراضيء لا يحتفظ جدول العرض إلا بجزء محدود من البيانات 
جاهزة في الذاكرة» بينما يترك لك مسئولية إمداده بقيم الخانات التي يحتاج لعرضها 
على الشاشة كلما تحرك المستخدم بالمنزلق الأفقي أو الرأسي.. هذا مفيد في 
الحالات التالية: 


2١ 


> 


عند التعامل مع مصادر بيانات لا يمكن ربطها مباشرة بجدول العرض» 
كالملفات الثنائية أو مجموعة مختلفة من المصفوفات أو غير ذلك. 

عند الحاجة إلى عرض كم هائل من البيانات» ففي الوضع الافتراضي لا 
يستهلك جدول العرض إلا جزءا محدودا من الذاكرة مهما زاد حجم البيانات 
التي تريد عرضهاء لأنه فعليا لا يحتفظ إلا بالجزء الذي يعرضه على 
الشناشة.. لهذا يكون الوضيع الافتراضي أكفا و اسر ع فى عرض البياننات 
الضخمة. 

عندما لا يكون هناك مصدر بيانات» وإنما يتم توليد البيانات بناء على معادلة 
أو شر ط أو ما شابه. . في هذه الحالة يوفر عليك الوضع الافتراضي عناء 
ملء مصفوفة أو قاعدة بيانات بالبيانات المولدة» ثم ربطها بجدول العرض 
كمصدر بيانات» ففي الوضع الافتراضي يمكن توليد قيمة الخانة مباشرة في 
الحدث 4ء لءءNعuا1]۷aه..‏ والمشر وع VirtualModeSample‏ يريك مثالا 
عاحى ساف ق عة رر الد ك اعد وا ون حا 
(أي خمسة ملايين خانة)» حيث يحتوي العمود الأول على الأعداد من ١‏ إلى 
مليون» بينما يحتوي العمود الثاني على مربع قيم العمود الأول» ويحتوي 
العمود الثالث على قيم العمود الأول آاس " وهكذاء وهو ما يمكن توليده 
بالمعادلتين التاليتين: 

قيمة أي خانة في العمود الأول = رقم الصف الذي توجد به + .١‏ 

(رقم العمود الذي توجد به + .)١‏ 

والآن لو جربت تشغيل هذا المشروع؛ فستجد أنه لن يستغرق وقتا قبل أن 
يظهر النموذج» وعليه جدول العرض وقد احتوى على الخانات مليئة 
بالأرقام. . في الحقيقة لم يستغرق ذلك وقتا لأن جدول العرض حسب فقط قيم 
الخانات التي تراها أمامك» وعندما تسحب المنزلق الرأسي إلى أسفل» 
فسيقوم بحساب قيم الخانات الجديدة التي ستظهر لك. . هذا يجعل التعامل مع 
خمسة ملايين خانة عملية في غاية السرعة والكفاءة! 


oA 


ويمنحك جدول العرض العناصر التالية للتعامل معه في الوضع الافتراضي: 


الوضع الافتراضي 5711013101006: 
إذا جعلت قيمة هذه الخاصية عuإ1»‏ فسيصير جدول العرض في الوضع 
الافتراضيء وعليك التحكم في كيفية عرض وتحديث قيم خاناته» وكيفية 
إضافة وحذف صفوفه. 


7# تحديث نص خطأ الصف 1extڵUpdateRowErro:‏ 
تجبر جدول العرض على إطلاق الحدث RowError 1 extN eed e4‏ لتحديث 
ولهذه الوسيلة صيغتان: 
.١‏ الصيغة الأولى تستقبل رقم الصف المراد تحديث نص خطئه.. ويمكنك 
استخدام ١-‏ للإشارة إلى صف رؤوس الأعمدة. 
؟. الصيغة الثانية تحدث نصوص الخطأ لنطاق من الصفوفء لهذا فهي 
تستقبل معاملين: رقم أول صف ورقم آخر صف في النطاق. 


7# تحديث معلومات ارتفاع الصف :UpdateRowHeightInfo‏ 
تجبر جدول العرض على إطلاق الحدث RowHeightInfoNeeded‏ 
وتستقبل هذه الوسيلة معاملين: 
+ رقم الضف المراد تحديك ازتقاضه: ويمكنك استخدام ١‏ للإشارة إلى 
صف رؤوس الاعمدة. 
- معامل منطقيء إذا جعلته 1:16 فسيتم تحديث ارتفاع كل الصفوف 
التالية للصف الذي أرسلت رقمه إلى المعامل الأول. 


17> تحديث قيمة الخانة :UpdateCelIValue‏ 
تجبر جدول العرض على إطلاق الحدث 0ع0611170101611660)»: لتحديث 
قيمة إحدى خانات جدول العرض.. وتستقبل هذه الوسيلة معاملين: 
د “رقم العموة الذىئ توحه ما الحافة : وييكنك استكداء -! للاقانة انى 
عمود رؤوس الصفوف. 
وق الصف الذى جف به الخافة:..وييكتك اتتام ٠١‏ للاشنارة إلى 
صف رؤوس الاعمدة. 
7# تحديث نص خطأ الخانة :UpdateCelIError Text‏ 
تجبر جدول العرض على إطلاق الحدث «CellErrorTextNeeded‏ 
لتحديث نص خطأ إحدى خانات جدول العرض.. ولها معاملان: 


o۹ 


- رقم العمود الذي توجد به الخانة.. ويمكنك استخدام ١-‏ للإشارة إلى 
عمود رؤوس الصفوف. 

- رقم الصف الذي توجد به الخانة.. ويمكنك استخدام ١‏ للإشارة إلى 
صف رؤوس الاعمدة. 


#۶ قيمة الخانة مطلوبة 011579167066060 ©: 
ينطلق عندما يرسم جدول العرض إحدى خاناته» ويحتاج منك إلى إمداده 
بقيمتها.. في هذه الحالة عليك حساب قيمة الخانة كما فعلنا في التطبيق 
عامصسددعل21510 نانك أو الحصول على قيمة الخانة من الملف أو 
المصفوفة أو المصفوفة القائمة ArrayList‏ التي تحتفظ فيها ببيانات الجدول. 
جع تضغاطء 2111 30110171601117 وهو يمتلك الخصائص التالية: 


5 بور | 120167ندن1ه00) | تعيد رقم العمود الذي يحتوي على الخانة. 
2 يور 2106 | تعيد رقم الصف الذي يحتوي على الخانة. 
Value‏ تعيد القيمة الموجودة حاليا في الخانة.. ويمكنك 
أن تحدم في هذه الخاصية القيمة الجديدة التي 


تريد أن تعرضها الخانة. 


#2 دفع قيمة الخانة :CellValue Pushed‏ 
ينطلق عندما يغير المستخدم قيمة إحدى خانات الجدول في وضعه 
الاقتراضي» كنك من حط القيمة الجديدة في وسيط القخرين الخاص بك 
(ملف أو مصفوفة أو غير ذلك).. والمعامل الثاني م لهذا الحدث من النوع 
وم 1خغطء 11611 ”10171601117 كما في الحدث السابق. 














۶۶ صف جديد مطلوب :NewRowNeeded‏ 
ينطلق بمجرد انتقال المستخدم إلى الصف الجديد (الصف الأخير) في جدول 
العرض في وضعه الافتراضي.. هذا يتيح لك وضع القيم الافتراضية في هذا 
الصف . لاحظ أن تحرير المستخدم لأية خانة في هذا الصف سيستدعي 
الحدث 061117111616600 لكل خانات الصف» ولو جربت هذا في 
المشروع 16م12ة7711131310065» فستجد أن خانات الصف الجديد قد 
امتلأت بكل الأرقام المحسوبة. 

#2 القيم الافتراضية مطلوبة :DefaultValuesNeeded‏ 
ينطلق عند إضافة صف جديد فارغ إلى نهاية جدول العرض» في وضعه 
الافتراضيء أو عندما يكون مرتبطا بمصدر بيانات. 


O 














والمعامل الثاني لهذا الحدث من النوع DataGridViewRowEventArgs‏ 
الذي تعرفنا عليه سابقاء ويمكنك استخدام الخاصية /12006.ج لملء خانات 


الصف بالقيم الافتراضية» مع ملاحظة أن هذه القيم ستحفظ مباشرة في مصدر 
البيانات» أو ستؤدي إلى انطلاق الحدث CellValuePushed‏ في الوضع 
الافتراضي لتتيح لك حفظها في وسيط التخزين الخاص بك. 


و إلغاء تحرير الصف :CancelRow Edit‏ 
ينطلق عند إلغاء تحرير أحد صفوف جدول العرض في وضعه الافتراضي. 
والمعامل الثاني ع لهذا الحدث من النوع ۶ع1۲ ve1۸‏ ٤stionمQu»‏ وهي 
يمتلك الخاصية المنطقية «Response‏ التي إذا جعلتها عنم[' كان هذا معناه 
الموافقة على تنفيذ الحدث (إلغاء التحرير)» إما إذا جعلتها 172156 كان هذا 
معناه رفض تنفيذ الحدث (وهذا معناه استمرار عملية التحرير وعدم إلغائها). 


#2 الحالة القذرة للصف مطلوبة :RowDirtyStateNeeded‏ 

ينطلق عندما يريد جدول العرض معرفة إن كان الصف الحالي قد حفظ 
التغييرات التي حدثت في خاناته أم لا.. والمعامل الثاني © لهذا الحدث من 
النوع »Question EventArgs‏ مع ملاحظة أنك إذا جعلت للخاصية 
56 القيمة 116 (وهي القيمة الافتراضية)» كان هذا معناه أن 
الصف لم يحفظ التغييرات بعد لهذا سينطلق الحدث Cance[Row Edit‏ إذا 
كان الد الغاء فاا التحر ين ت الزن ا إها إذا جعلت تي 
هذه الخاصية مو[إه۴» كان هذا معناه أن الصف قد حفظ التغييرات» ولن 
ينطلق الحدث 32061190111016 ©. 


33 نص خطأ الصف مطلوب :RowErrorTex(Needed‏ 
ينطلق عندما يحتاج جدول العرض إلى النص الذي يحتوي على الأخطاء التي 
حدثت في الصف الحالي» وذلك عندما يكون جدول العرض في الوضع 
اراسي أو عندما يكون مرتبطا بمصدر بيانات.. والمعامل الثاني ع لهذا 
الحدث من النوع «DataGridViewRowErrorTextNeededEventArgs‏ 
وهو يمتلك الخاصيتين التاليتين: 


2 يون | 101202 | تعيد رقم الصف. 
ننةة] | 810164 | ضع في هذه الخاصية نص الخطأ الخاص بالصف. 














۶۶ نص خطأ الخانة مطلوب :CelIError TexNeeded‏ 


o١ 











ينطلق عندما يحتاج جدول العرض إلى النص الذي يحتوي على الأخطاء التي 
حدثت في الخانة الحاليةء وذلك عندما يكون جدول العرض في الوضع 
الافتراضيء أو عندما يكون مرتبطا بمصدر بيانات.. والمعامل الثاني م لهذا 
الحدث من النوع «DataGridViewCellErrorTextNeededEventArgs‏ 


بور | 120622 طن[ ه") | تعيد رقم العمود الذي توجد به الخانة. 
ي | 25011006 | تعيد رقم الصف الذي توجد به الخانة. 

| 0۲16 | ضع في هذه الخاصية نص الخطأ الخاص 
بالخانة. 














۶ نص تلميح الخانة مطلوب 6060 »011100111762001 ©: 
ينطلق عندما يحتاج جدول العرض إلى نص التلميح الخاص بإحدى خاناته؛ 
وذلك عندما يكون جدول العرض في الوضع الافتراضيء أو عندما يكون 
›DataGridViewCellToolTipTextNeededEventArgs‏ وهو يمتلك 
الخضائصن القالية: 


9 بور | :0011120 | تعيد رقم العمود الذي توجد به الخانة. 
ي ٠‏ 12501715206 | تعيد رقم الصف الذي توجد به الخانة. 

تم | ×1 "0111p‏ | ضع في هذه الخاصية نص تلميح الشاشة 
الكاص اة 














# رف القائمة الموضعية للصف مطلوب :RowContextMenuStripNeeded‏ 
ينطلق عندما يضغط المستخدم بزر الفأرة الأيمن على أحد الصفوف طالبا 
عرض القائمة الموضعية؛ وذلك عندما يكون جدول العرض في الوضع 
الافتراضي» أو عندما يكون مرتبطا بمصدر بيانات.. هذا مفيد عندما تريد 
تدر يعسن عاضر القائسة الو عة تدا لي بات الق ر خالقه: 
والمعاممل الثاني و لهذا المخدث من التوع 
<DataGridViewRowContextMenuStripNeededEventArgs‏ وو 
يمتلك الخاصيتين التاليتين: 


ي ٠‏ 0م1801 | تعيد رقم الصف. 
اسع | «nt»‏ | ضع في هذه الخاصية كائن رق القائمة الموضعية 
ContextiMenuStrip | MenuStrip‏ التي تريد عرضها. 











# رف القائمة الموضعية للخانة مطلوب :CellContextMenuStripNeeded‏ 


o۲ 






































ينطلق عندما يضخط بزر الفأرة الايمن على إحدى الخانات ولت 
الافتراضي» أو a‏ هذا مفيد عندما تريد 
تغيير بعض ا القائمة الع ل الخالة او حالتها. 
استخدمتها في الحدث .RowContextMenuStripNeeded‏ 
DataGrid ViewCellErrorTextNeededEventArgs‏ وهو يمتلك 


9 ين | ×علصلصصد اه٤‏ تعيد رقم العمود الذي توجد به الخانة. 
اي | 25071206 | تعيد رقم الصف الذي توجد به الخانة. 

| »اوه أ ضع في هذه الخاصية كائن رق القائمة 
MenuStrip‏ | الموضعية م115)3ء/0016723) التي تريد 
عرضها. 














و معلومات ارتفاع الصف مطلوبة :RowHeightInfoNeeded‏ 
ينطلق عندما يحتاج جدول العرض إلى تغيير ارتفاع أحد الصفوفء وذلك 
عندما يكون جدول العرض في الوضع الافتراضيء أو عندما يكون مرتبطا 
بمصدر بيانات.. هذا مفيد عندما تريد تغيير ارتفاع بعض الصفوف بعد 
تزتها و العا الاي الها الخدت مسق اللبوع 
›»DataGridViewRowHeightInfoNeededEventArgs‏ وهو يمتلك 


الخصائص التالية: 

2 ير RowIndex‏ تعيد رقم الصف. 

و لجا Height‏ ضع في هذه الخاصية ارتفاع الصف. 

MinimumHeight | 8‏ ضع في هذه الخاصية أقل ارتفاع مسموح 
به للصف. 














#2 دفع معلومات ارتفاع الصف :RowHeightInfo Pushed‏ 
ينطلق عندما يغير المستخدم ارتفاع أحد الصفوف» وذلك عندما يكون جدول 
العرض في الوضع الافتراضيء أو عندما يكون مرتبطا بمصدر بيانات. 
والمعام ل الثاني ع لهذالحدث من التوع 
›DataG rid View RowHeightInfoPushedEventArgs‏ وهو يمتلك 
الخضبائصن الثالية: 


oc 


























ير RowlIndex‏ تعيد رقم الصف. 

Height a7‏ تعيد ارتفاع الصف. 

9 وو | MinimumHeight‏ | تعيد أقل ارتفاع مسموح به للصف. 
Handled‏ إذا جعلت قيمة هذه الخاصية 116 » فلن 


يتغير ارتفاع الصف» وسيظل بنفس 
الارتفاع السابق قبل أن يحاول المستخدم 














تحسين أداء جدول العرض: 

رأينا في هذا الفصل» كيف أن جدول العرض أداة غنية تمتلك قدرات هائلة.. 
للأسف» هناك عيب في هذا الأمر» يظهر عند عرض عدد بهم كن اللسماات في 
جدول العرض» فكل تلك الفئات التي تتعامل مع الأعمدة والصفوف والخانات بكل 
ما تحتويه من خصائص» تحتاج إلى مساحة كبيرة في الذاكرةء مما يقلل من كفاءة 
جدول العرض عند التعامل مع عدد ضخم من السجلات.. في هذه الحالة مثلاء قد 
يكون تحريك المنزلق لعرض صفوف معينة عملية ثقيلة وبطيئة» وكذلك عرض 
قائمة موضعية؛ وما إلى ذلك» إضافة إلى بطء البرنامج ككل بسب العبء على 
الذاكرة! 

ولحسن الحظء لم يقف مصممو هذه الأداة العملاقة عاجزين أمام هذا العيب» 
فوضعوا بعض المعايير التي تساعد على تحسين أداء جدول العرض عند التعامل 
مع عدد ضخم من الصفوف والأعمدة.. ومنها: 

«DataGrid View.DefaultCe1IStyle لتغيير شكل الخانات؛» استخدم الخاصية‎ -١ 
فأي تغيير في هذه الخاصية ترثه جميع الخانات التي ليس لها طراز خاص‎ 
بنفسهاء مما يجعل استهلاك الذاكرة أقل ما يمكن مهما كان عدد الخانات‎ 
هائلا.. ولا تلجأ إلى تغيير طراز كل خانة على حدة من خلال الخاصية‎ 
إلا في أضيق الحدود» لأن كائن طراز كل‎ 2151© 
خانة يستهلك مساحة من الذاكرة.‎ 

١‏ لاتغير ط رز الخالنة من خلال قالب الصف 
DataGridView .Row Template‏ لأن هذا سينشئ نسخة خاصة من 
كائن الطراز لكل صف في الجدول» وسيكون هذا عبئا كبيرا إذا كان في 
الخدول الاق الصفوف ` 1 

۳- إذا كانت بعض الخانات تعرض البيانات بتنسيق خاصء فلا تغير التنسيق 
من كائن الطراز الخاص بالصفوف أو الأعمدة أو الخانات» بل استخدم 
الحدث عمنااهمإه 11۴ء٥‏ لتغيير تنسيق الخانة عند عرضها.. هذا سيوفر 


ot 

















مساحة الذاكرة» ولن يستهلك وقتا ملموسا في التنفيذء لأن هذا الحدث 
ينطلق فقط للخانات التي تظهر للمستخدم على الشاشةء وليس كل الخانات. 
عند قراءة طراز الخانة» استخدم الخاصية 16571 بدلا من 
الخاصية 5/16, لأن الخاصية مار تنشئ كائن طراز جديد إذا حاولت 
قراءتها وهي فارغة! 
استخدم الخاصية م00111670161115111) لوضع قائمة موضعية لجدول 
العردن ككل ول تضم :قائية مو ضفي لكل ضيف أو مود أو خانة على 
حدة 
لا تضع قائمة موضعية لقالب الصف ع2[ مدمعء103]20110516.1201» 
لأن هذا سينشئ نسخة من القائمة الموضعية لكل صف في الجدول. 
إذا كنت تحتاج إلى قائمة موضعية مختلفة لكل صف» فاستخدم الحدث 
11510116600 ]123 لعرض القائمة الموضعية للصف 
ERR‏ 
إذا كنت تحتاج إلى قائمة موضعية مختلفة لبعض الخانات» فاستخدم الحدث 
e1] ntextMenuStripNeeded‏ لعرض القائمة الموضعية للخانة 
AA‏ 
لا تستخدم التحجيم التلقائي ع4110-5121, على مستوى جدول العرض 
إذا كان يحتوي على عدد هائل من الخانات» لأن حساب أنسب عرض 
وارتفاع للصفوف والأعمدة» يستلزم إجراء عمليات قياس لأبعاد محتويات 
جميع الخانات!.. وإذا كان التحجيم التلقائي مهما لك» فيمكنك أن تنفذه على 
الخانات المعروضة فقط وذلك بوضع القيمة 11501356006115 أو القيمة 
DisplayedCellsExceptHeaders‏ في الخاصية «AutoSizeMode‏ 
وإذا أردت تحج يم رءوس الت ع هفو ف للفائ ت ا 
فاس تخمم القيبسمة «AutoSizeToDisplayedHeaders‏ أو 
01 ر.ر الكن الأفضل على الإطلاق» منع التحجيم 
التلقائي نهائياء وقيامك بتنفيذه برمجياء بكتابة الكود الذي يقيس عرض 
وارتفاع محتويات الخانات في الأحداث التالية: 

.UpdateRowHeightInfo - 

.Scroll - 

.RowDividerDoubleClick - 

.ColumnDividerDoubleClick - 


-٠‏ عند التعامل مع الأعمدة والصفوف والخانات المحددةء استخدم 


المجمورعع ات SelectedColumns‏ و 5616016019055 
و 5616016006115 بحذرء لآن كفاءتها تكون سيئة إذا كان الدول يحتوي 
على عدد ضخم من الخانات. 


oto 


-0١‏ استخدم الوسيلة DataGrid View.GetCelICount‏ لمعرفة عدد 
الخانات المحددةء بدلا من استخدام الخاصية .SelectedCe1ls.Count‏ 
5- استخدم الوسيلة Rows .GetR ow Cou‏ لمعرفة عدد الصفوف 
المحددةء بدلا من استخدام الخاصية .SelectedRows.Count‏ 
-١7‏ استخدم الوسيلة 664001000114 6.ومدن1[ه© لمعرفة عدد الأعمدة 
المحددة؛ بدلا من استخدام الخاصية .SelectedColumns.Count‏ 
-٤‏ تجنب السماح للمستخدم بتحديد الخانات بصورة منفردة» وبدلا من هذا 
ضع في الخاصية Selectioı Mode‏ القيمة FulIRowSelect‏ أو 
.FullColumnSelect‏ 
5- حافظ على الصفوف المشتركة 100185 513160 بقدر الإمكان.. ولكن.. 
ما الضرذوف المشتركة؟.. هدا هو مرکو افر ة الكالية. 


الصفوف المشتركة :Shared Rows‏ 
فكرة هذه التقنية بسيطة»ء فكل صف جديد يتم إنشاؤه في جدول العرض يأخذ 
خصائصه الشكلية من قالب الصفوف ماهامإ٥۲ ٠W‏ 8؛ لهذا لا داعي لأن نحجز 
له مساحة كاملة في الذاكرة لنكرر فيها نفس البيانات المشتركة مع القالب.. هذا 
موف اة كور 5 فين الذاكر و خا ذا كان عيدة صينر ف حورل الو كلق 
كما لي ارك الضحف ا (استكدمت أيه خاضنية لتقيو رة عر شيم 

بل إن مجرد تعامل المستخدم مع أي خانة في الصف يلغي مشاركته! 

لهذا لا تفيدك تقنية مشاركة الصفوف» إلا إذا كان جدول البيانات يحتوي على عدد 
هائل من الخانات» ولا يتوقع أن يتعامل المستخدم مباشرة إلا مع عدد قليل منها. 

كما أن هذه التقنية غير مفيدة إذا كان جدول العرض لا يرتبط بمصدر بيانات» لأن 
وضع أي قيمة في الخانة يلغي مشاركة الصف» وهذا منطقي» لأن حفظ هذه القيمة 
في الذاكرة يحتاج إلى إنشاء كائن الخانة وبالتالي كائن الصف الذي توجد به 
بينما في وجود مصدر بيانات خارجي سواء من خلال تقنية الربط ع نكما أو 
من باستخدام الوضع الافتراضي 71006 77110131 - لا يحتاج جدول العرض إلى 
حفظ القيم في الذاكرة» فهو يجلبها من مصدر البيانات عند الحاجة» ويرسمها في 
الخانات مباشورة 


وتنص قاعدة المشاركة على أنه: 

يمكن مشاركة الصف فقط إذا كان من الممكن معرفة خصائص كل خانة من 
خاناته من خصائص الصف والعمود اللذين توجد فيهما. 

ويتم إلغاء مشاركة الصف إذا تغيرت حالة خانته» بحيث لا يعود من الممكن 


استنتاج خصائصها من خصائص الصف والعمود.. وهذه بعض الأمثلة على 
الحالات التي تلغى فيها مشاركة الصف: 
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تحديد خانة منفردة في الصف» دون أن تكون في عمود محدد.. لو أردت 
منع هذه الجالة قاد نشي العيرككد :كدي إخادة متفر ده 

وضع قيمة في الخاصية Too1Tip1ext‏ أو ContextMenuStrip‏ 
لإحدى خانات الصف.. ويمكنك تجاوز هذه الحالةء باستخدام الحدثين 
CellToolTipTextNeeded‏ و CellContextMenuStripNeeded‏ 
لعرض تلميح الشاشة والقائمة الموضعية عند الحاجة إليهما. 

وجود قائمة منسدلة في إحدى خانات الصف» ووضع عناصر في الخاصية 
ns‏ الخاصة بها بدون استخدام تقنية الربط. 


ويمكنك استخدام الإرشادات التالية لإنشاء الصفوف المشتركة والمحافظة عليها في 
حالة المشاركة: 
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تجنب استخدام الصيغة التي تستقبل مصفوفة من القيم عند إضافة صف 
جديد إلى مجموعة الصفوف 12078 باستخدام الوسيلة 400 أو 056116]» 
لأن هذه الصيغة تضع القيم في خانات الصف مما يلغي مشاركته. 
لاحظ أن الصف الجديد الموجود في نهاية جدول العرض هو صف غير 
Mh‏ ك 1 
تجنب التعامل مع الصف من خلال مجموعة الصفوف RON‏ وتجنب 
المرور عبر الصفوف باستخدام حلقة التكرار ط٥8۵‏ إه۴.. وبدلا من هذا 
استخدم الوسائل البديلة التي تستقبل رقم الصف للتعامل معه؛ مثل الوسائل 
«GetErrorT'ext «GetContextMenuStrip‏ 
.GetState ‘GetPreferredHeight‏ 
تجنب التعامل مع الخانة من خلال المجموعة DataGrid ViewRow.Cells‏ 
لان هذا يلعي مشاركة الصيفه الذي ترد فيه. 
لك المعامل م في الأحداث التي تنطلق CS‏ 
الخانة فهذه الخصائص لا تلغي مشاركة الصف. 
استخدم الخاصية و11400165ع0011650) للحصول على رقم العمود 
ورقم الصف اللذين توجد فيهما الخانة» فهذا لا يلغي مشاركة الصف. 
استخدم الخاصية س0 R0 Ws.S14إ١4 ۸R‏ للحصول على كائن الصف دون 
ملاحظة أن هذه التغييرات ستؤثر على كل الصفوف المشتركة معه! 
استخدم الوسيلة Get ContextMenuStrip‏ للحصول على القائمة 
الموضعية للصف المشترك. لأن الخاصية ContextMenuStrip‏ 
الخاصة بالصف المشترك ستجد أن رقمه ١-‏ ولن تعيد القائمة الموضعية 
بصورة صحيحة. 
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۸- لا تستخدم الحدثين CollectionChanged‏ و RowStateChanged‏ 
الخاصين بمجمو عة الصفوف» لأنهما يلغيان مشاركة الصفوف. 

۹- إذا كانت للخاصية SelectionMode‏ القيم FullColumnSelect‏ أو 
ColumnHeaderSelect‏ أو FullRowSelect‏ أو RowHeaderSelect‏ 
فلا تتعامل مع الصفوف المحددة من خلال الخاصية 
GridView .Selected Cells‏ لأنها ستلغي مشاركة الصفوف 
المحددة في هذه الحالة! 

-٠‏ إذا كانت للخاصية ©1051/00]عه561 القيمة ]عع1 061196 فلا تستخدم 
الوسيلة 1411ء (t46 r14 View .Se1e‏ لأنها ستلغي مشاركة الصفوف. 

-١‏ لا تستخدم الوسيلة DataGridView.AreA1ICellsSelected‏ لأنها 
تلغي مشاركة الصفوف! 

- لا تضع القيمة 172156 في الخاصية 1263001715 أو 5616160 الخاصة 
بالخانة» إذا كان لأي من هاتين الخاصيتين القيمة مإ في العمود الذي 
توجد فيه الخانة. 

7- لا تستخدم الخاصية DataGrid View.Rows.List‏ لأنها تلغي 
مشاركة جميع الصفوف! 

-٤‏ لا تستخدم الصصيغة DataGrid View.Sort([Comparer)‏ لوسيلة 
الترتيب» لأن استخدام فئة مقارنة خاصة يلغي مشاركة جميع الصفوف» 
بسبب حاجة فئة المقارنة إلى التعامل مع نسخ من الصفوف التي تقارنها. 

15 استخدم الحدث مرج ایو € Row‏ أثناء تصميم البرنامج لرصد الحالات 
التي تلغي مشاركة الصفوف» وحاول تجنبها. 

وللتأكد من أن الصف مشتركء» استخدم الوسيلة 513160190397 الخاصة بمجموعة 
الصفوف للحصول على كائن الصف» ومن ثم افحص رقم هذا الصفء فإن كان ١-‏ 
فهذا معناه أنه صف مشترك» فكما ذكرنا سابقاء الصف المشترك رقمهدائما ..!١-‏ 
والمثال التالي يخبرك إن كان الصف الأول مشتركا أم لا: 
If DataGridView]. Rows. SharedRow(0).Index = -1 Then‏ 
( "هذا الصف مشتركڭ' )×80 Msg‏ 
End If‏ 
أخيرا: أحتاج إلى تذكيرك إلى أن كل هذه المحاذير» تتعلق فقط بالحالة التي تتعامل 
فيها مع جدول بيانات يحتوي على عدد هائل من الصفوف يقدر بالالاف.. وإن 
شئت نصيحتيء عليك الهروب من هذه الحالة المعقدة لأنها أساسا غير عمليةء فلا 
يمكن للمستخدم أن بيستعرضص آلاف السجلات دفعة ةواحدة.. لهذا أنصح باستخدام 
تقسيم جدول العرض إلى صفحات عاع22: 
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من تعامل مع جدول العرض في تطبيقات مواقع الإنترنت 
ASP.NET Web Applications‏ يعرف أن جدول العرض الخاص بها يسمح 
بعرض البيانات في صورة صفحات» كل منها تحتوي على عدد من السجلات 
٠١(‏ أو ٠١‏ مثلا)» ويعرض الجزء السفلي من جدول العرض أرقام الصفحات 
المتاحة في صورة روابطء وعند ضغط أي منهاء يتم عرض السجلات المناظرة 
لهذه الصفحة في جدول العرض 
ولا أدري لماذا لم تقدم ميكروسوفت هذه التقنية البسيطة والجميلة في جدول 
العرض الخاص بتطبيقات الويندوز» فهي أسهل وأكفأ وأكثر ملاءمة للمستخدم من 
تقية الصفوف المشثر كه 
لهذاء دعنا ننشئ نحن بأنفسنا هذه التقنية.. الأمر بسيطء فكل المطلوب هو أن ننشئ 
موصل جدول له معاملان: الأول يستقبل رقم السجل والثاني يستقبل عدد السجلات 
المطلوبة» وذلك للحصول على عدد معين من سجلات الجدول بدءا من موضع 
معين.. وسنضع تحت جدول العرض عددا من لافتات الوصلات ع201.آكلطةآ 
لنعرض فيها أرقام الصفحات» وعند ضغطها نحمّل السجلات المطلوبة من قاعدة 
البيانات إلى مجموعة البيانات» ومن ثم نعرض هذه السجلات في جدول العرض 
من خلال تقنية الربط. . بهذه الطريقة سنحصل على وفر هائل في الذاكرة» ليس فقط 
بسبب قلة عدد سجلات جدول العرضء ولكن أيضا بسبب قلة سجلات مجموعة 
البيانات» فحتى لو كانت تقنية مشاركة الصفوف تقلل من مساحة الذاكرة التي 
يستهلكها جدول العرضء إلا أنها لا تفعل شيئا حيال حجم الذاكرة التي تستهلكها 
مجموعة البيانات!.. هذا إضافة إلى سرعة تحميل البيانات من قاعدة البيانات» 
بسبب تقسيمها إلى أجزاء صغيرة. 
وعليك اختيار عدد مناسب من السجلات لعرضه في كل صفحة.. ربما يكون العدد 
5 مناسبا لتطبيقات الويندوز» فهو عدد معقول بالنسبة للمستخدم» ولا يمثل عبئا 
ضخما على الذاكرة.. وعموماء لقد عرفنا الثابت 120378170 على مستوى النموذج» 
ويمكنك تعديله بسهولة للتعامل مع العدد الذي يناسبك من السجلات 
والان» دعنا نرى كيف ننفذ هذه الفكرة: 
- ابدأ مشروعا جديدا اسمه عمزع 1(21201101716122.. وستجده مرفقا 
بأمثلة الكتاب. 
- من القائمة العلوية ج4ج(1 اضغط الأمر «Add New Data Source‏ 
واتبع خطوات المعالج السحري لإضافة جدولي المؤلفين والكتب إلى 
- افتح مخطط قاعدة البيانات واضغط موصل جدول المؤلفين 
Authors able Adapter‏ بزر الفأرة الأيمن» ومن القائمة الموضعية 
اضغط الأمر «Configure‏ وعدل الاستعلام ليصير كالتالي: 
SELECT * FROM dbo.Authors‏ 
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WHERE ID BETWEEN @StartID AND @EndID 
واضغط زر الموافقة.. سيعدل هذا الوسيلة ۴111 بإضافة معاملين لهاء‎ 
أحدهما اسمه (5601611 والآخر اسمه ۰8115 وبهذا يتم تحميل السجلات‎ 
المحددة فقط من جدول المؤلفين.‎ 
اضغط موصل جدول المؤلفين عام ھل 1۸ط 1ء0rطtںAu بزر الفأرة‎ 
الأيمن» ومن القائمة الموضعية اضغط الأمر :0161© ۸4ء وتابع‎ 
خطوات المعالج السحري لإضافة استعلام يعيد قيمة منفردةء باستخدام‎ 
جملة ,5001 التالية:‎ 
SELECT MAX(ID) FROM Authors 
هذه الدالة ستخبرنا برقم‎ ..GetM ax2 وسم م الدالة التي تنفذ هذا الاستعلام‎ 
آخر مؤلف في جدول المؤلفين» لنستخدمه في معرفة عدد الصفحات‎ 
اللازمة لعرض كل المؤلفين.‎ 
اضغط موصل جدول الكتب ع1م 800151816403 بزر الفأرة الأيمن»‎ 
ومن القائمة الموضعية اضغط الأمر ع7ناع0018» وعدل الاستعلام‎ 
ليصير كالتالي:‎ 
SELECT Books.* FROM 00.1001, Authors 
WHERE AuthorlId = Authors.ID 
AND Authors.ID BETWEEN @StartID AND @EndID 
واضغط زر الموافقة.. سيعدل هذا الوسيلة ۴111 بإضافة معاملين لهاء‎ 
أحدهما اسمه 5[٤إه)S والآخر اسمه ۴412 وبهذا يتم تحميل كتب‎ 
المؤلفين الذين نتعامل معهم حاليا فقط.‎ 
لاحظ أن موصل البيانات لن ينشئ أوامر التحديث والإدراج والحذف‎ 
الخاصة بجدول الكتب تلقائيا بسبب وجود عملية ربط في استعلام التحديد..‎ 
لهذا يتعين عليك إنشاء هذه الأوامر بنفسك إن كنت تريدها.‎ 
انتقل إلى النموذج» ومن القائمة العلوية وه اضغط الأمر‎ 
لعرض نافذة مصادر البيانات.. اسحب جدول‎ 5507377 Data Sources 
المؤلفين وأسقطه على النموذج.. سيضيف هذا إلى النموذج جدول عرض‎ 
والأدوات اللازمة لربطه بجدول المؤلفين» مع وضع رف أدوات علوي»‎ 
يسمح للمستخدم بإدخال قيمتي المعاملين 54۲۲12 و (80011 مع زر تنفيذ‎ 
عملية الملء عنوانه ۴11.. هذا جميل.. يمكنك أن تترك هذه الإمكانية أيضا‎ 
للمستخدم» ليحدد بنفسه السجلات التي يريد عرضهاء لكن مع تغيير عناوين‎ 
اللافتات لتصير عربية كما في الصورة:‎ 
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1 من4 ›* ١0لا‏ 
بدءا من المؤلف رقم: 12 انتهاء بالؤلف رقم: 15 تنفيذ 








لا تنس استخدام محرر مجموعة الأعمدة من نافذة الخصائص لإخفاء 
العمود 1201717615100 أو تغيير نوعه من عمود صورة إلى عمودي 
نصيء حتى لا يسبب أخطاء.. استخدم نافذة الخصائص أيضاء لإضافة 
عمود إلى الجدول يعرض أزرارا وامنحه الاسم ع[018060©. 

أضف نموذجا آخر إلى المشروع اسمه 11280015» وضع عليه جدول 
عرض لنعرض فيع كتب المؤلف. 

انقر جدول العرض مرتين بالفأرة لعرض كود الحدث 
Click‏ مع مه 110ع).: واكتب فيه الكود الذي يعرض النموذج 
55 ويعرض كتب المؤلف الحالي فيه.. لقد فعلنا هذا من قبل في 
المشروع DataGrid ViewAuthorBooks‏ ولن نكرر شرحه هنا. 
«BooksTable Adapter‏ لاس تخذامة في ل جدول الكتب بكتب 
المؤلفين المعروضين في الصفحة الحالية.. لاحظ أنك تستطيع إحضار كتب 
كل آل ت من قاعدة ان اتاك مياقينة عند الحاجة إلى عر ححا لكن هذا 
سيزيد من عدد مرات الاتصال بقاعدة البيانات أثناء تعامل المستخدم مع 
المؤلفين المعروضين في الصفحة الحالية.. لهذا من الأفضل أن نحضر كل 
كتب هؤلاء المؤلفين مباشرة ونحفظها في مجموعة البيانات.. ونظرا لأن 
كل صفحة ستحتوي على 75 مؤلفاء ومع افتراض أن لكل مؤلف ٠١‏ كتب 
في المتوسط فإننا سنضع في الذاكرة حوالي +5؟ كتابا. هذا رقم معقول 
ولا يقلقنا.. وعلى كل حال» أنت المسئول من خلال التجربة والخطأء عن 
تحديد أي من الطريقتين تجعل برنامجك يعمل أسرع دون أن يخنق الخادم 
أو جهاز المستخدم. 

ضع لافتة رابط 1.1011.2061] على النموذج وامنحها الاسم 1122861 1]» 
وضع فيها النص ,."١"‏ واعرضها أسفل الجدول كما هو واضح في 
الصورة السابقة.. اضبط خط هذه اللافتة وثبت حافتيها اليمنى والسفلي 


باستخدام الخاصية Anchor‏ .. سنستخدم هذه اللافتة كقالب نستمد منه 
خصائص باقي لافتات الرابط التي سنضيفها في وقت التشغيل. 
انقر لافتة الرابط مرتين بالفأرة لكتابة كود الحدث 0ع1010011»1.].. كود 
هذا الحدث بسيط للغاية» فنحن نستطيع حساب رقم أول مؤلف نريد 
عرضه» من خلال الرقم الذي تعرضه اللافتة باستخدام المعادلة التالية: 
ا ١‏ ع اموت كر Gm‏ الصا )١-‏ 
رقم النهاية - رقم البداية + عدة الخد فى ا 
علما بأن رقم الصفحة؛ هو النص الذي تعرضه اللافتة الحالية.. لاحظ أن 
هذا الحدث سيستجيب لأكثر من لافتة رابطء لهذا سنس تخدم المعامل 
لمعرفة اللافتة التي ضغطها المستخدم. 
الآن» صار من السهل أن نملا جدولي المؤلفين والكتب بالسجلات.. هذا هو 
الكود: 1 
Dim Lnk = CType(sender, LinkLabel)‏ 
Dim StartID = 1 + RowsNo * (CInt(Lnk.Text) - 1)‏ 
AuthorsTable Adapter.Fill(BooksDataSet. Authors,‏ 
StartID, StartID + RowsNo)‏ 
BooksTableAdapter.Fill(BooksDataSet. Books, StartID,‏ 
StartID + RowsNo)‏ 
يتبقى لنا الآن كتابة كود حدث تحميل النموذج» لإنشاء لافتات الصفحات.. 
يجب أن نحسب أولا عدد الصفحات المطلوبة» وذلك بقسمة رقم آخر مؤلف 
على عدد الصفوف التي سنعرضها في كل صفحةء مع تقريب الكسر إلى 
أكبر عدد صحيح: 
Dim MaxID = AuthorsTableAdapter.GetMaxID‏ 
Dim PagesNo = Math.Ceiling(MaxID / RowsNo)‏ 
بعل هذا سننشئ لافتات الرابط التي ستعرض هذه الصفحات» ووضع کل 
منها بجوار اللافتة التي تسبقها بمسافة كافية. . في البداية نحن نعرف أن 
اللافتة السابقة هي اللافتة «LnkPage1l‏ وبعد هذا يجب أن نحتفظ بكل 
لافقة نضيفها في متغير اسمه )م P۲۷]‏ لنستخدمها في ضبط موضع 
اللافتة التالية لها.. علينا أيضا أن نضبط خط اللافتة ونثبت حوافهاء 
ونربطها بالحدث المستجيب لضغط الرابط.. هذا هو الكود: 
Dim PrvLnk = LnkPage1‏ 
For I =2 To PagesNo‏ 
Dim Lnk As New LinkLabel‏ 
Me.Controls.Add(Lnk)‏ 


Lnk. Visible = True 
Lnk.Text = I 
Lnk.Font = PrvLnk.Font 
Lnk.AutoSize = True 
Lnk.Location = PrvLnk.Location - 
New Point(Lnk.Width + 10, 0) 
Lnk.Anchor = PrvLnk.Anchor 
AddHandler Lnk.LinkClicked, 
AddressOf LnkPagel LinkClicked 
PrvLnk = Lnk 
Next 
ستكون بلا تأثير إذا وضعت فيها عںإآ‎ Aںام‎ Sze لاحظ أن الخاصية‎ 
قبل أن تضيف لافتة الربط إلى أدوات النموذج.. لهذا أضفنا اللافتة إلى‎ 
أدوات النموذج أولاء وضبطنا خطهاء ووضعنا في الخاصية 167 النص‎ 
الذي ستعرضه» قبل أن نجعلها تغير حجمها تلقائيا لتناسب محتوياتها.‎ 
والآن» سيكون من الأفضل لو ضغطنا نحن رابط أول لافتة لنعرض أول‎ 
صفحة من صفحات المؤلفين في جدول العرض بمجرد تشغيل البرنامج..‎ 
لكن نظرا لأن لافتة الربط لا تملك الوسيلة ع2611011101101 الخاصة‎ 
LnkPagel LinkClicked بالأزرار» فسنضطر إلى استدعاء الحدث‎ 
بأنفسنا كالتالي:‎ 
LnkPagel LinkClicked(LnkPage1, 
New LinkLabelLinkClickedEventArgs(Nothing)) 
لو شغلت البرنامج الآن» فسيعرض جدول العرض أول صفحة من صفحات‎ 
المؤلفين» ويمكنك أن تضغط رابط أي صفحة أخرى لعرضها.. ولو ضغطت زر‎ 
عرض كتب أي مؤلف» فسيظهر النموذج الثاني وعليه كتب هذا المؤلف.‎ 
يبدو كل شيء جيدا.. لكن للأسف هناك مشكلة صغيرة» تحدث بسبب طريقة تقسيم‎ 
11( الصفحات التي نستخدمها!.. فنحن لا نضمن انتظام أرقام المؤلفين لأن الحقل‎ 
ويليه مؤلف رقمه‎ »١ وليس‎ ٠١ مولد تلقائيا.. لهذا قد تجد أن أول مؤلف يبدأ بالرقم‎ 
مثلاء وذلك بسبب حذف سجلات أخرى ضيعت الترقيم الوسيط!.. لهذا قد نجد‎ ° 
صفحات تعرض عددا من السجلات أقل من العدد المطلوب» وأحيانا قد تظهر‎ 
صفحات ليس فيها أية سجلات على الإطلاق!‎ 
ولحل هذه المشكلة علينا تغيير طريقة تقسيم الصفحات» وهو مافعلناه في‎ 
في هذا المشروع تركزت معظم‎ ..Data6G ri4 ViewPaعinع2 المشروع‎ 
التغييرات على استعلامات موصلات الجداول» مع قليل من التعديلات في الكود.‎ 
دعنا نفهم فكرة التقسيم الجديدة:‎ 


في البداية لو أردنا ملء أول صفحة بعدد من المؤلفين 2000111)» فسنس تخدم 
الاستعلام التالي» وهو الذي ستجده في الوسيلة عع1”11215]52: 
SELECT TOP (@Count) * FROM Authors‏ 
وسيتم ملء كتب هؤلاء المؤلفين بالوسيلة ع2 ۴11۳۴۲۴ في موصل جدول الكتب 
بالاستعلام التالي: 
SELECT *‏ 
FROM Books INNER JOIN‏ 
Authors ON Books.AuthorID = Authors.ID‏ 
WHERE Authors.ID IN‏ 
SELECT TOP (@Count) ID FROM Authors)‏ 
لاحظ أن هذا الاستعلام مركب» فهو يستخدم جملة 83818٣1‏ ثانية للحصول على 
أرقام المؤلفين المعروضين في أول صفحة؛ والتأكد أن رقم المؤلف الذي نحصل 
على كتبه يقع ضمن هذه الأرقام. 
هذا جميل.. لكن كيف نحصل على المؤلفين في الصفحات الأخرى غير الصفحة 
الأولى؟ 
المشكلة هنا أننا لا نعرف ترقيم أول مؤلف في هذه الصفحات» فكما ذكرنا من قبلء 
يتسم حقل الترقيم التلقائي بعدم الانتظام! 
لحل هذه المشكلة. > علينا معرفة ترقيم آخر مؤلف تم عرضه في الصفحة السابقة 
للصفحة الحالية.. افترض أن الصفحة التي سنعرضها ستبدأ بالمؤلف الحادي 
عشر.. هذا معناه أن الصفحات السابقة عرضت ٠‏ مؤلفين.. يمكننا إذن أن نحصل 
على أرقام أول ٠١‏ مؤلفين من الجدول كالتالي: 
SELECT TOP (11 -1)‏ 
ID FROM Authors AS PrvPages‏ 
ORDER BY ID‏ 
ويمكننا أن نحصل على ترقيم اخر مؤلف منهم باستخدام الدالة ×۸" كالتالي: 
((11) 425لا SELECT‏ 
FROM (‏ 
SELECT TOP (11 -1)‏ 
ID FROM Authors AS PrvPages‏ 
ORDER BY ID‏ 
AS MaxID‏ ) 
معاملا اسمه 11101710 @ وهو الرقم الفعلي للمؤلف الذي يظهر في بداية 
الصفحة» وليس ترقيمه التلقائي الموجود في الحقل (1].. هذا الرقم يساوي: 
١‏ + عدد الصفوف في الصفحة × (رقم الصفحة ١-‏ ) كما شرحنا من قبل. 
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والآن» بعد أن حصلنا على ترقيم آخر مؤلف عرضناه في الصفحة السابقةء يمكننا 
أن نقرأ السجلات التي يزيد ترقيمها عن ترقيمه. ونأخذ منها فقط العدد 
111 0)00).. هذا هو الاستعلام الكامل: 
SELECT TOP (@Count)‏ 
FROM Authors‏ * 
WHERE ID > )‏ 
SELECT MAX(D)‏ 
FROM (‏ 
SELECT TOP (@AuthorNo -1)‏ 
ID FROM Authors AS PrvPages‏ 
ORDER BY ID‏ 
AS MaxID‏ ) 


ملحوظة: 

ستضاف جملة التحديد بعد أمر التحديث وأمر الإدراج» وهذا سيسبب أخطاء في 
و عند حفط التييرات» بسيب ونجود معاملين ان يتم إرسال فيمتيهينا.. . لهذا 
الخيارات المتقدمة Advanced Options‏ أثناء تنفيذ المعالج السحري» أو 
يمكنك فعله من نافذة الخصائص بعد انتهاء المعالج.. حدد موصل جدول 
المؤلفين» وافتح نافذة الخصائص وأسدل خصائص أمر التحديث 
1210310 وغير قيمة الخاصية ]2 001012101.. لاحظ أن أمر 
التحديد يوجد في سطر جديد» لهذا لن تستطيع التعامل معه في خانة القيمة لأنها 
تعرض سطرا واحدا فقط.. للتحايل على هذاء حدد السطر الظاهر 
(هذا هو أمر التحديث) وقصه ]00)» ثم الصقه مرة ثانية ع2251.. هكذا تكون قد 
تخلصت من أمر التحديد.. ويمكنك فعل نفس الشيء مع أمر الإدراج الموجود 
في الخاصية .InsertCom mand‏ 








ولكي نحصل على كتب هؤلاء المؤلفين» سنكون استعلاما يضمن أن ترقيم المؤلف 
الذي نقرأ كتبه يقع ضمن أرقامهم كالتالي: 

SELECT * FROM Books 

INNER JOIN Authors 

ON Books.AuthorID = Authors.ID 

WHERE Authors.I[D IN 











( 
SELECT TOP (@Count) 
ID FROM Authors 
WHERE ID > 
( 
SELECT MAX(D) 
FROM ( 
SELECT TOP (@AuthorNo -1) 
ID FROM Authors AS PrvPages 
ORDER BY ID 
) AS MaxID 


) 


واضح أن هذا أعقد استعلام كتبناه حتى الآن.. لكن لا تدعه يربكك» فكل ما هو بعد 
الكلمة ×1 في هذا الاستعلام هو نفس الاستعلام الذي استخدمتاه في موضل جدول 
المؤلفين» مع فارق واحد: أننا هنا نقرأ الحقل (11 فقط وليس كل حقول جدول 
المؤلفين» لأننا نريد استخدام الحقل (11 في جملة الشرط. 

يمكنك الآن ترد 8 لمر و ..DataGridViewPaging2‏ ستجده ده يعمل بشكل 


من اا رت ال قا رضن عددا اقل من ایر عسي عدم وجو 
E‏ ت عن ت معندات ال لايك . ولا ينقص هذه 
التقنية إلا شيء واحد. . فمن المستحيل وضع كل أرقام الصفحات في لافتات الربط 
عندما يكون عدد الصفحات كبيرا ٠٠١(‏ صفحة مثلا). . في هذه الحالة عليك أن 
تعرض أول عشرة أرقام فقط» مع وضع لافتة مكتوب عليها "التالي"» وعند الضغط 
عليها تعرض عشرة أرقام تالية» مع عرض لافتة في البداية اسمها "السابق"» عند 
الضغط عليها تعرض ٠١‏ أرقام سابقة. 
دعنا نرى كيف نفعل هذا: 
النص "السابق". 
- أضف لافتة رابط أخرى اسمها )1.1672 تعرض النص "التالي". 
5 عرف ثابتا على مستوى النموذج اسمه 15م1.آ:11 لتتحكم به في أقصى 
عدد يمكن عرضه من الروابط. 
- عرف المتغيرات التالية على مستوى النموذج: 
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«PageLinks -١‏ وهو قائمة مخصصة للتعامل مع لافتاتالروابط 
(abe1ا Link‏ ist)0۴fاء‏ لنضع فيها مراجع إلى لافتات الروابط التي 
تعرضها على النمودج.. هذا سيسهل غلبا التحكم فى هذة الروابط 
هر الصفحة النناطرة لهنا ي جدرل الخرضر) . هذا TE‏ 
التحرك إلى الأماة أو الخلف عند خط "التالي" أو "السابق". 

؟- »۴rstPageN0‏ وهو متغير يحمل رقم أول صفحة يظهر حاليا في 
لافتات الروابط.. في البداية تكون قيمة هذا المتغير ١ء‏ ويمكن أن يتغير 
إذا عرضنا مجموعة أخرى من الروابط بسبب ضغط "التالي". 

«PagesNo 51‏ وهو متغير يحمل عدد الصفحات الكلي الذي نتعامل معه. 

في حدث تحميل النموذج» سنعدل حلقة التكرار التي تضيف اللافتات» بحيث 

يكون أقصى عدد نضيفه هو 10[19.]آ22:2.. يتم هذا كالتالي: 

For I =2 To Math.Min(PagesNo, MaxLinks) 


Next 
سيظل كود حلقة التكرار كما كان في المشروع السابق» ما عدا زيادة سطر‎ 
واحد» يضيف كل لافتة ننشئها إلى المجموعة ومام عه۴.. لا تنس أيضا‎ 
إضافة اللافتة الأولى 1ءعه۴ )م إلى القائمة:‎ 
PageLinks.Add(LnkPage1) 
For I = 2 To Math.Min(PagesNo, MaxLinks) 
' نفس الكود القديم‎ 
PageLinks.Add(PrvLnk) 
Next 
استخدم الحدث 4ء )نا٣ )م لتعطيل الرابط "السابق" إذا كان رقم الرابط‎ 
المضغوط ١ء وتعطيل الرابط "التالي" إذا كان رقم الرابط المضغوط يساوي‎ 
عدد الصفحات*‎ 
Dim I = .كلططآ)غام1ن)‎ Text) 
LnkPrev.Enabled = (I1 > 1) 
LnkNext.Enabled = )1 < PagesNo) 
سيكون من المفيد أيضا أن نميز الرابط المضغوط حاليا عن باقي الروابط‎ 
وذلك بتعطيله (فلا فائدة من ضغطه ثانية) وخعل خطة سكا و عاك إعاذة‎ 
الرابط السابق إلى وضعه الطبيعي قبل تغيير حالة الرابط المضغوط حاليا..‎ 
أنسب مكان لفعل هذا هو الحدث 0ع 11010111 أيضا:‎ 
' إعادة الرابط السابق إلى وضعه الأصلي‎ 
CurLink.Enabled = True 
CurLink.Font = New Font(CurLink.Font, 


oo 


FontStyle.Regular) 
' تمييز الرابط الحالي‎ 


٠ 
Cr 


Lnk.Enabled = False 

Lnk.Font = New Font(Lnk.Font, FontStyle.Bold) 
CurLink = Lnk 

في حدث ضغط "التالي" سنضغط الرابط الذي يزيد رقمه عن الرابط الحالي 


بواحد» إن كان معروضا على الشاشة: 
Dim I = CurLink. Text‏ 


LnkPagel LinkClicked(PageLinks(l - FirstPageNo + 1), 

, New LinkLabelLinkClickedEventArgs(Nothing)) 
أما إذا كان الرابط السابق هو آخر رابط معروض على الشاشة»ء فيجب أن‎ 
نعرض مجموعة تالية من الروابط.. لفعل هذا لا نحتاج إلى حذف الروابط‎ 
الحالية وإنشاء روابط جديدةء فبإمكاننا أن نغير الأرقام المعروضة على‎ 
اللافتات ببساطة» وذلك بجمع القيمة 1مز.آ:212 على كل منها.. لاحظ أن‎ 
ناتج الجمع قد يتجاوز إجمالي عدد الصفحات في بعض الحالات» لهذا علينا‎ 
0ه لتشير إلى رقم أول رابط في المجموعة الجديدة من‎ 

الروابط.. هذا هو كود الحدث كاملا: 
Dim I = CurLink.Text‏ 
If 1 = MaxLinks Then‏ 
For Each Lnk In PageLinks‏ 
Lnk.Text += MaxLinks‏ 
If Lnk.Text > PagesNo Then Lnk.Visible = False‏ 
Next‏ 
FirstPageNo += MaxLinks‏ 
End If‏ 
LnkPagel LinkClicked(PageLinks(I - FirstPageNo + 1),‏ 
New LinkLabelLinkClickedEventArgs(Nothing))‏ 
أخيراء لم يتبق لنا إلا حدث ضغط "السابق".. هذا الكود مشابه لكود حدث 
ضغط "التالي", مع عكس عمليات الجمع الل طرح» وإظهار اللافقات 
المختفية.. كما أن شرط عرض المجموعة السابقة من اللافتات» هو أن يكون 
الرباط المضغوط حاليا أول رابط معروض على الشاشة.. هذا هو الكود: 
Dim I = CurLink.Text‏ 
If I = FirstPageNo Then‏ 
For Each Lnk In PageLinks‏ 
Lnk.Text -- MaxLinks‏ 
Lnk.Visible = True‏ 
Next‏ 


FirstPageNo -- MaxLinks 
End If 
LnkPagel LinkClicked(PageLinks(l - FirstPageNo - 1), 
New LinkLabelLinkClickedEventArgs(Nothing)) 
الآن» يمكنك تشغيل البرنامج والاستمتاع بتجربته.. ستجد أن لديك بالفعل جدول‎ 
عرض مقسم إلى صفحات» يعمل بكفاءة تامة» وقدرات كاملة!‎ 


ملحق: ١‏ 
الفئات التى يستخدمها جدول عرض البيانات 


سنشر ح في هذا الملحق كل الفئات التي يحتاجها جدول العرض 103120110117165 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


01۰ 


DataGridViewElement Class 


DataGridViewBand Class 
DataGridViewColumn Class 


DataGridViewButtonColumn Class 
DataGridViewCheckBoxColumn Class 
DataGridViewComboBoxColumn Class 

DataGridViewlmageColumn Class 

DataGridViewLinkColumn Class 


DataGridViewTextBoxColumn Class 


DataGridViewRow Class 


DataGridViewCell Class 
DataGridViewButtonCell Class 
DataGridViewCheckBoxCell Class 
DataGridViewComboBoxCell Class 
DataGridViewlmageCell Class 
DataGridViewLinkCell Class 
DataGridViewTextBoxCell Class 


DataGridViewHeaderCell Class 


DataGridViewColumnHeaderCell 


DataGridViewRowHeaderCell 


اكه 


4 فئة عنصر جدول العرض DataGridView Element Class‏ 


هذه هي الفئة الأم التي تشتق منها كل عناصر جدول العرض: الأعمدة والصفوف 


57 ف جدول العرض :DataG rid View‏ 
تعيد كائن جدول العرض 17313611017167 الذي ينتمي إليه العنصر. 


57 هن الحالة مStat:‏ 


تعيد إحدى قيم المرقم sعt۾†E1emen†S hata Grid View‏ التي توضح حالة 


العنصرء من بين القيم التالية: 
None‏ العنصر في حالته الافتراضية. 
Frozen‏ العنصر مجمد (مثبت).. هذا معناه أنه يظل ظاهرا في 
موضعه مهما تحرك المستخدم بالمنزلق. 
1157 العنصر للقراءة فقطء ولا يستطيع المستخدم تغيير قيمته. 
1651231 | يمكن للمستخدم تغيير موضع وحجم العنصر في الجدول.. 
لاحظ أن هذه القيمة يتم تجاهلها إذا لم يتم دمجها مع القيمة 
.ResizableSet‏ 
51 || العنصر مستقل في قابلية تغيير حجمه» عن العنصر 
الرئيسي الذي ينتمي إليه. 
Selected‏ العنصر مد حاليا Highlighted‏ . 
4 العنصر ظاهر للمستخدم حاليا دون الحاجة إلى تحريك 
المنزلق لعرضه. 
١15116‏ العنصر مرئي (غير مختفي).. هذا صحيح حتى لو كان 
العنصر غير معروض 1015013360 على الشاشة بسبب 
موضعه من المنزلق. 











ويعمل هذا المرقم كمؤشر ع713» لهذا يمكن أن تعيد هذه الخاصية أكثر من 
قيمة مدمجة معاء وعليك فحص القيمة التي تريدها باستخدام المعامل لہ ۸: 


If (DataGridView1.Rows(0).State And 


DataGridViewElementStates.Displayed) > 0 Then 
MsgBox(DataGridView1.Rows(0).State. ToString) 


End If 





























42 فئة نطاق جدول العرض DataGrid ViewBand Class‏ 


هذه الففة ترث الفئة غعدمع123301105/16171: كما أنها تمثل الواجهتين 
I[Cloneable‏ و .IDisposable‏ 

وتعمل هذه الفئة كفئة أم تشتق منها أعمدة وصفوف جدول العرضء ولعل هذا 
يوضح سبب تسمية هذه الفئة باسم النطاق 21820 فهي تمثل نطاقا من الخانات تقع 
في صف معين أو عمود معين. 


وتمتلك هذه الفئة الخصائص الثالية: 


= رف القائمة الموضعية :ContextMenuStrip‏ 

تقرأ أو تغير كائن رف القائمة الموضعية ContextMenuStrip‏ الذي 
يعرض القائمة الموضعية للنطاق الحالي.. هذا معناه أنك تستطيع استخدام 
قائمة موضعية مختلفة لكل صف» ولكل عمود!.. وتظهر القائمة الموضعية 
كما تعرف عند الضغط بزر الفأرة الأيمن فوق أي خانة في النطاق» ما عدا 
خانة و ادن النطاق. 1 ١‏ 
لاحظ أن أولوية القائمة الموضعية تكون كالتالى: 

أ تظلير الان الموخطية للفاقة ان وهدت: 

۲- تظهر القائمة الموضعية للصف إن وجدت. 

۳- تظهر القائمة الموضعية للعمود إن وجدت. 
هذا معناه أن الخانة التى توجد فى صف له قائمة موضعية وعمود له قائمة 
اه کح درطي القائمة البورطجية القاهدة الك و اسن الوه 


وخ النوع الافتراضي لخانة العنوان 6م11159ع:12212111611620610: 
ضع في هذه الخاصية كائن النوع 6م7597 الذي يمثل نوع خانة العنوان (رأس 
العمود)» بشرط أن تكون قيمة هذه الخاصية من نوع الفئة 
1ع 11711162062 أو أي فة مشتقة منها.. وسنتعرف على 
هذه الفئات بالتفصيل لاحقا. 
وتفيدك هذه الخاصية إذا أردت تغيير شكل ووظيفة خانة رأس الصف أو 
»DataG rid View ColumnHeaderCell‏ ومنحها الشكل والأداء الذي 
تريده» ثم وضع نوعها في الخاصية DefaultHeaderCe11 Type‏ لكل 
عمود في جدول العرضء لتظهر كخانة رأس لكل منها. 

3 مجمد ررءع1"102: 


إذا جعلت قيمة هذه الخاصية ‘True‏ فسيتم تثبيت ند تثبيت النطاق الحالي في موضعه 
مهما حرك المستخدم المنزلق الأفقي أو الوأسي.. هذا مفيد إذا أرت استخدام 
أحد الصفوف أو الأعمدة كعنوان ثابت بحيث يظل مرئيا باستمرار. 

لاحظ أنك تستطيع تثبيت النطاق (الصف أو العمود) إذا كان أول نطاق أو 
يسبقه نطاق مثبت» وغير هذا يحدث خطأ في البرنامج. 


37 ف رقم العنصر ٥×‏ لہ]: 

تعيد رقم النطاق الحالي في الجدول.. فإذا كان النطاق الحالي صفاء تعيد 
توھ کے مسر ا عقوف انت رلو كا ان الهانى عرد تعد 
موضعه الأصلي في مجمو عة الأعمدة. 
لاحظ أن تغيير المستخدم لموضع العمود بسحبه بالفأرة (إذا كنت تسمح له 
بترتيب الأعمدة) لا يؤثر على رقم العمود في مجموعة الأعمدة» وإنما يؤثر 
فقط على موضع عرضه 1(15013371062.. لكن على العكس» يتغير موضع 
الصف في مجموعة الصفوف» إذا ضغط المستخدم رأس أحد الأعمدة لترتيب 
الصفوف على أساسه.. لهذا لا تحتفظ برقم الصف في متغير طوال تشغيل 
البرنامج» لأنه قد يتغير في أي لحظة. وبدلا من هذا احتفظ بمتغير من النوع 
077 بشير إلى الصف الذي تريده. 


وخ الطراز الافتراضي للخانة :DefaultCel1IStyle‏ 
تقرأ أو تغير كائن طراز الخانة 12312001101716170611516716 الذي يتحكم 
في شكل خانات النطاق الحالي.. وسنتعرف على الففة 
11516 بالتفصيل لاحقا. 


# ف يوجد طراز افتراضي للخانة :HasDefaultCe1|IStyle‏ 
تعيد 11 إذا كنت قد وضعت قيمة في الخاصية ع]Default(Ce11Sty..‏ 
لاحظ أن الخاصية 126151114061156716 لا تعيد عمنط710 أبداء فلو كانت 
فارغة وحاولت قراءتهاء فسيتم إنشاء طراز افتراضي ووضعه فيها!.. لهذا 
يمكنك استخدام الخاصية 11351(618111406115616 أولا لمعرفة إن كانت 
الخاصية 106191110011561 فارغة أم لا. 


7 ف الطراز الموروث :InheritedStyle‏ 
تعيد كائن طراز الخانة 102]20109/1650061154/16 الذي يتم تطبيقه على 
النطاق الحالي. . وتعيد هذه الخاصية الطراز الموضح في الخاصية 
11551 إذا كانت لها قيمة» وإلا فإنها تعيد الطراز الموروث من 
جدول العرض. 


وخ للقراءة فقط :و[م(©206»ع12: 
إذا جعلت قيمة هذه الخاصية 1516» فلن يستطيع المستخدم تغيير قيمة أي 
خانة في النطاق الحالي. 


3 قابل للتحجيم bl]eۆResiza‏ : 

تحدد إن كان بإمكان المستخدم تغيير حجم النطاق الحالي (تغيير عرض 
العمود أو ارتفاع الصف) باستخدام الفأرة.. وهي تأخذ إحدى قيم المرقم 
hata Grid ViewTriState‏ التالية: 

01561 | لم يتم تحديد قيمة الخاصية؛ وسيتم استخدام القيمة الافتراضية 
الموروثة من جدول العرض. 

م | توضع القيمة 106" في الخاصية. 

۴6 | توضع القيمة ع1219 في الخاصية. 











وع محدد 0ع]عع561: 
إذا جعلت قيمة هذه الخاصية ع1۲٠‏ فسيتم تحديد النطاق الحالي.. كما تعيد 
هذه الخاصية ع٣1‏ إذا كان النطاق الحالي محددا سواء بواسطتك أو بواسطة 
المستخدم.. لاحظ أن تحديد النطاق الحالي لا يلغي تحديد النطاقات الأخرى»› 
فجدول العرض يتيح تحديد أكثر من صف أو عمود معا. 
لاحظ أن هذه الخاصية تتأثر بقيمة الخاصية 5616011051/1006 الخاصة 
بجدول العرض كالتالي: 
- إذا كانت للخاصية 561600031006 أي قيمة غير FulIRowSelect‏ 
و »RowHeaderSelect‏ فإن الخاصية )5610 الخاصة بالصف 
تكون بلا تأثير لأن جدول العرض لا يسمح بتحديد الصفوف. 
- إذا كانت للخاصية 561610011006 أي قيمسة غير 
FullColumnSelect‏ و umnHeaderSelectاCoء‏ فإن الخاصية 
عا الخاصة بالعمود تكون بلا تأثير لأن جدول العرض لا يسمح 
بتحديد الاأعمدة., 


37 لفن معروض 1(15712760: 














تعيد ع1[ إذا كان النطاق الحالي ظاهرا للمستخدم على الشاشة دون الحاجة 
إلى استخدام المنزلق الأفقي أو الرأسي. 


“نا مرئي 616زو71؟: 
إذا جعلت قيمة هذه الخاصية «False‏ فسيتم إخفاء النطاق الحالي وعدم 


3 الوسم ع1'2: 


هذه هي الخاصية الإضافية» التي تستطيع أن تضع فيها أي كائن يحوي 
معلومات تهمك تتعلق بالنطاق الحالي. 


2 فئة أساس المجموعة BaseColIection Class‏ 


هذه الفئة تمثل الواجهة 1001160110» وهي تعمل كمجموعة عادية؛ ولكنها لا 
تحتوي على أية وسائل تتيح لك إضافة العناصر إليها.. كل ما تحتويه هو العناصر 
التاليةء وهي مألوفة لنا فقد شرحناها بالتفصيل في كتاب برمجة إطار العملء لهذا 


لن نعيد شرحها هنا: 

IsReadOnly BF Count HT 
SyncRoot FF IsSynchronized i 
GetEnumerator # CopyTo # 


90 ا مجمورعة اعد حذول اله ضف 


DataGrid ViewColumnCollection Class 


هذه الفئة ترث الفئة 8356001161410 كما أنها تمثل واجهة القائمة ]11,15» وهي 
تحتوي على عناصر من نوع فة عمود ج دول العرض 
.DataGridViewColumn Class‏ 
ولحدث إنشاء هذه المجموعة صيغة واحدة؛ تستقبل كائن جدول العرض 
107177 الذي ستنتمي إليه مجموعة الأعمدة.. مثال: 
Dim Cols As New DataGridViewColumnCollection(‏ 
DataGridView1)‏ 
في الحقيقةء لا يبدو إرسال جدول العرض كمعامل إلى حدث ذا مغزىء فبعد تنفيذ 
الجملة السابقة لن يتغير شيء في مجموعة الأعمدة الخاصة بجدول العرض 
71 ووولن تكون له أية صلة بالمجموعة الجديدة و001©» والتي 
بدورها ستكون فارغة ولن تحتوي على أية أعمدة موجودة حاليا في جدول العرض 
!!DataGridView1‏ 


وتمتلك مجموعة الأعمدة العناصر التقليدية للمجموعات» والتي تستقبل كمعامل 
كائن العمود أو نصا يمثل اسم العمود.. لهذا دعنا نركز هنا على العناصر التالية: 


> إضافة 400: 
تصيف عمودا إلى مجموعة الأعمدة» وتعيد رقما صحيحا يمثل موضع هذا 
العمود في المجموعة.. ولهذه الوسيلة الصيغتان التاليتان: 

DataGridViewColumn الصيغة الأولى تستقبل كائن العمود‎ -١ 
وتضيفه إلى المجموعة.‎ 

-١‏ الصيغة الثانية تستقبل نصا يمثل اسم العمود» ونصا يمثل عنوان 
العم« وتنشئ عمودا نصيا DataGridViewTextBoxColumn‏ 
وتضيفه إلى المجموعة.. والمثال التالي يضيف إلى جدول العرض 
عمودا نصيا اسمه 011) وعنوانه "عمود١":‏ 

("عمود DataGridView1.Columns.Add("'C011'", "١‏ 
وتتسبب هذه الوسيلة في حدوث خطأ في البرنامج في الحالات التالية: 

- إذا كان العمود المراد إضافته موجودا في جدول العرض من قبل. 

- إذا كان الجدول يحتوي على صف أو أكثرء بينما للخاصية 
م6115 الخاصة بالعمود القيمة .Nothing‏ 

- إذا كان العمود الجديد مثبتا وع2٠إ۴»‏ وأضفته وسط أعمدة غير مثبتة. 


- إذا كان جدول العرض يقوم بتحديد كل خاناته في تلك اللحظة أو يزيل 
تحديدها أو يغير قيم الخاصية DisplayIndex‏ لكل الأعمدة. 

- إذا تم استدعاء الوسيلة ل۸4 من داخل أي من الأحداث التالية: 
CellEnter, CellLeave, CellValidating, CellValidated,‏ 

RowEnter, RowLeave, RowValidated, Row Validating. 

- إذا كانت للخاصية 501137006 الخاصة بالعمود القيمة icاaدAuton»ء‏ 
بينماللخاصية ع02100ع1031300110171659.5616 القيمة 
FullColumnSelect‏ أو .ColumnHeaderSelect‏ 

- إذا كانت للخاصية nheritedAut0oS1zeM0deا‏ الخاصة بالعمود 
القيمة e۲‏ ل12 umnادC»‏ بينما عناوين الأعمدة غير معروضة 
.(DataGridView.ColumnHeadersVisible = False)‏ 

- إذا كانت للخاصية ]nheritedAutoSize Mode‏ القيمة [۴11› بينما 
العمود مثبتا .(Frozen = True)‏ 


وجا اعلض :Ttem‏ 


هذه هي الخاصية الافتراضية؛ وهي تعيد كائن العمود 
DataGrid ViewColumn‏ الذي ترسل إليها اسمه أو رقمه كمعامل.. 
والكود التالي يعرض رقم العمود 0011 الذي أضفناه في المثال السابق: 
MsgBox(DataGridView1.Columns("Co011").Index)‏ 


معرفة عدد الأعمدة :GetColumnCount‏ 
تعيد عدد أعمدة الجدول التي لها الحالة المرسلة كمعامل» وهي تستقبل إحدى 
قيم المرقم .DataGridViewElementStates‏ . والمثال التالي يعرض عدد 
اا المحددة في جدول العرض 
MsgBox(DataGridView1.Columns.GetColumnCount(‏ 
DataGridViewElementStates.Selected))‏ 


معرفة عرض الأعمدة :GetColumns Width‏ 
تعيد مجموع عروض أعمدة الجدول التي لها الحالة المرسلة كمعامل» وهي 
تستقبل إحدى قيم المرقم ..DataG rid ViewElementStates‏ والمثال 
التالي يخبرك بعرض الأعمدة المرئية في الجدول: 
MsgBox(DataGridView1.Columns.GetColumns Width (‏ 
DataGridViewElementStates. Visible))‏ 
معرفة أول عمود :GetFirstColumn‏ 


تستقبل إحدى قيم المرقم DataGrid ViewElementStates‏ وتعيد أول 
عمود له الحالة المرسلة.. وتعيد هذه الوسيلة عمط إذا لم تجد عمودا له 
العالة المظلوية. 
وتوجد صيغة أخرى لهذه الوسيلة لها معامل ثان هو أيضا من نوع المرقم 
5 وولكنه يستقل الحالة التي يجب ألا يكون 
عليها العمود.. والمثال التالي يعيد أول عمود مرئي لكنه غير معروض 
للمستخدم: 
Dim DgCol As DataGrid ViewColumn =‏ 
DataGridView1.Columns.GetFirstColumn(‏ 
DataGrid ViewElementStates. Visible,‏ 
DataGridViewElementStates.Displayed)‏ 


7# معرفة آخر عمود :GetLastColumn‏ 
فمائلة الوديلة السلقة ولكنيا دبد آخن عفرة اله الحالة التوشخة في المعاسل 
الأول وليست له الحالة الموضحة في المعامل الثاني. 


17> معرفة العمود التالي :GetNextColumn‏ 
تعيد كائن العمود مناه ٣سwع1‏ 546۲11۷ الذي يحقق الشروط الموضحة 
في المعاملات» وهي بالترتيب: 
-١‏ كائن العمود مدصu‏ اھ٣ View‏ 4ا (ta6‏ الذي سيبدأً البحث منهء 
للعثور على أول عمود يليه يحقق الشروط المطلوبة. 
۲- إحدى قيم المرقم DataGrid ViewElementStates‏ توضح الحالة 
التي يجب أن يمتلكها العمود المطلوب. 
۳- إحدى قيم المرقم DataGrid ViewElementStates‏ توضح الحالة 
التي يجب ألا يمتلكها العمود المطلوب. 
وتعيد هذه الوسيلة 7101418 إذا لم تجد عمودا يحقق الشروط المطلوبة. 
والمثال التالي يعرض أسماء كل الأعمدة الظاهرة للمستخدم والتي لا يستطيع 
Dim Cols = DataGridView1.Columns‏ 
Dim DgCol = Cols.GetFirstColumn(‏ 
DataGridViewElementStates.Displayed,‏ 
DataGridViewElementStates.Resizable)‏ 


Do Until DgCol Is Nothing 

MsgBox(DgCol.Name) 

DgCol = Cols.GetNextColumn(DgCol, 
DataGridViewElementStates. Displayed, 
DataGridViewElementStates.Resizable) 

Loop 


#> معرفة العمود السابق :GetPreviousColumn‏ 
مماثلة للوسيلة السابقة فى معاملاتهاء ولكنها تبحث عن العمود السابق للعمود 
المرسل للمعامل الأول» الذي يحقق الشروط المطلوبة.. دعنا نعيد كتابة المثال 
السابق باستخدام هذه الوسيلة مع الوسيلة :)6113560011 6: لعرض أسماء 
الأعمدة بترتيب عكسي: 
Dim Cols = DataGrid 1745‏ 
Dim DgCol = Cols.GetLastColumn(‏ 
DataGridViewElementStates.Displayed,‏ 
DataGridViewElementStates.Resizable)‏ 
Do Until DgCol Is Nothing‏ 

MsgBox(DgCol.Name) 

DgCol = Cols.GetPreviousColumn(DgCol, 
DataGridViewElementStates. Displayed, 
DataGridViewElementStates.Resizable) 

Loop 


2 المجموعة تغيرت :ColIlectionChanged‏ 
ينطلق هذا الحدث عند حدوث تغير فى عناصر المجموعة بالحذف أو 
الايكافة, اال ا ي و اذا ا م او 
19+ وقد تعرفنا عليه من قبل عند التعرف 
على مجموعة الجداول .DataTableCollection‏ 


OV» 


4 فئة عمود جدول العرض DataGrid ViewColumn Class‏ 


هذه الفئة ترث الفئة DataGrid View Band‏ وتمثل الواجهة .I[Component‏ 
وتعمل هذه الفئة كعمود في جدول عرض البيانات» ولحدث إنشائها صيغتان: 
١ك‏ الضبيفة الأولى يدوق ساملات 
؟- والصيغة الثانية تستقبل كائن خانة 11ع1(31300110116500 لوضعه في 
الخاصية ع136م7مء06111) الخاصة بالعمود.. هذه الخانة ستعمل كقالب 
611 تنسخ منه كل خانة تضاف إلى العمود عند إضافة صف جديد 
إلى الجدول. 


وتمتلك هذه الفتثة الخصائص التالية: 


ونج الاسم :Name‏ 
قرا أو تغير اسم العمود.. هذا الاسم لا يظهر كعنوان له» وإنما يستخدم 
كمعرف للعمود داخل مجموعة الأعمدة» لاستخدامه مع بعض الوسائل مثل 
Remove‏ و .Contains‏ 


و- نوع القيمة :Value Typ»‏ 
ضع في هذه الخاصية كائن النوع 6م19: الذي يمثل نوع بيانات خانات 
العمود الحالي, 


وخ نص تلميح الأداة )جرع 1 100113: 
ضع في هذه الخاصية النص الذي تريد عرضه للمستخدم عندما يحلق بالفارة 
7 العرض 1571060: 
تقرأ أو تغير عرض العمود الحاليء والقيمة الافتراضية لها هي .٠٠١‏ 
Ji‏ عرض :Minimum Width‏ 
تقرأ أو تغير اقل عرض ممكن للعمودء بحيث لا يمكن ڌ تصغيره عنه برمجيا 
أو عند سحب المستخدم لحافته بالفأرة لتغيير حجمه.. والقيمة الافتراضية لهذه 


ا طريقة الحجم التلقائي 41100512601006: 


الاه 


تحدد كيف يتم تغيير حجم العمود تلقائياء وهي تأخذ إحدى قيم المرقم 
10ج »10011011716151 التالية: 


NotSet‏ طريقة تحجيم العمود موروثة من جدول العرض. 


None‏ لا يتم ضبط عرض العمود تلقائيا. 
AllCells‏ ضبط عرض العمود ليلائم محتويات كل خاناته» بما 
في ذلك خانة العنوان. 


AllCells‏ ضبط عرض العمود ليلائم محتويات كل خاناته» ما 
ExceptHeader‏ | عدا خانة العنوان. 
٠ Displayed 5‏ ضبط عرض العمود ليلائم محتويات كل خاناته 
الظاهرة على الشاشة حالياء بما في ذلك خانة العنوان. 
5 ام ضبط عرض العمود ليلائم محتويات كل خاناته 
1 ا الظاهرة على الشاشة حالياء ما عدا خانة العنوان. 
١| 1111‏ ضبط عرض العمود ليلائم محتويات خانة العنوان.. 
وتسبب هذه القيمة خطأ في البرنامج إذا كان جدول 
الع رض يخقى عتارين الأعندة 
.(ColumnHeadersVisible = False)‏ 
Fill‏ ضبط عرض العمود الحالي مع باقي الأعمدة لمحاولة 
ملء مساحة جدول العرض كلها.. وتسبب هذه القيمة 
خطأ في البرنامج إذا كان العمود مثبتا 2٥إ۴.‏ 


لاحظ أن المستخدم يستطيع جعل العمود يأخذ الحجم المناسب لمحتوياتهء 
بمجرد النقر مرتين بالفأرة فوق الحافة اليمنى لخانة العنوان. 











“57 ف طريقة الحجم التلقائي الموروثة :Inherited AutoSize Mode‏ 
00 القيمة «NotSet‏ فإن الخاصية InheritedAutoSize Mode‏ 
تعيد القيمة الموروثة من جدول العرض. 


كلاه 





























أولوية الملء :FilI|Weight‏ 
تقرأ أو تغير الوزن النسبى لكل عمود» لاستخدامه فى معرفة كيفية ملء 
سياه ول الد و اليك دا ااا 
AutoSizeMode‏ القيمة [۳11.. والقيمة الافتراضية لهذه 
الخاصية هي ٠٠١‏ ويمكنك زيادتها أو إنقاصهاء حيث يتم تكبير العمود الذي 
له وزن أكبرء أكثر من العمود الذي وزن أصغر.. الذي يحدث هو حساب 
مجموع قيم هذه الخاصية لكل الأعمدة (وليكن 511)» ثم ضرب كل عمود 
في القيمة (5110/#طع1ء11119177).. لاحظ أن أقصى قيمة للمجموع 51110 
يجب ألا تزيد عن وإلا حدث خطأ في البرنامج: لهذا لا تضع قيما 
كير فى قدي الخاسي O ٠‏ السك في كبر MS‏ الحيرة كي كدر 


“ا طريقة الترتيب ©501:0031006: 
تقرأ أو تغير طريقة ترتيب خانات الجدول» وهي تأخذ إحدى قيم المرقم 
1115010 اااسلتالية: 


0311م / هذه هي القيمة الافتراضية للجداول التي تعرض خانات 
نصية وهي تسمح للمستخدم بضغط رأس العمود 
بالفأرة» لترتيب صفوف الجدول تبعا خانات هذا 
العمود.. ويظهر في خانة العنوان مثلث يشير رأسه إلى 
اتجاه الترتيب» ويمكن تغيير اتجاه الترتيب بضغط رأس 
العمود بالفأرة مرة أخرى.. وتسبب هذه القيمة خطأ في 
البرنامج إذا كانت للخاصية 56161105171006 الخاصة 
بدول العهرض القيمسة FullColumnSelect‏ أو 
.ColumnHeaderSelect‏ 

116 الا يمكن للمستخدم إجراء عملية الترتيب» ورغم أنه ما 
يزال بإمكانك إجراء الترتيب برمجياء فلن يحتوي رأس 
العمود على مساحة لعرض علامة الترتيب.. وهذه هي 
القيمة الافتراضية للجداول التي تعرض خانات تحتوي 
على أزرار أو صور أو مربعات اختيار أو قوائم منسدلة 
أو.وضلات 

Programmatic‏ مماثلة للقيمة السابقة» لكن رأس العمود سيحتوي على 
مساحة لعرض علامة الترتيب. 











كلاه 














وتستطيع منح كل عمود في الجدول طريقة ترتيب مختلفة عن غيره.. يمكنك 
مثلا أن تسمح للمستخدم بترتيب الجدول عندما يضغط رأس العمود الذي 
يعرض المفتاح الأساسي فقطء بينما تجعل باقي الأعمدة غير قابلة للترتيب. 
لاحظ أنك لو ربطت جدول العرض بقائمة )1.35 فان ضغط رؤوس الأعمدة 
لن يؤدي إلى إعادة ترتيب الجدول! 
السبب في هذا أن جدول العرض لا يقوم بعملية الترتيب بنفسه» وإنما يطلب 
من مصدر البيانات عع12348501 المرتبط به أن يقوم هو بتنفيذ عملية 
الترتيب تبعا للخاصية التي يرتبط بها العمود المضغوط.. لهذا يجب أن يكون 
مصدر البيانات قابلا للترتيب 106" = ع155018016» وهذا غير متوفر في 
القوائم 1.1565 والمجموعات 0011601025 ولا حتى في قائمة الربط 
.BindingList‏ 
ولحل هذه المشكلةء قمت بتتبع الأكواد التي تستخدمها ميكروسوفت» فوجدت 
أنها تستخدم فئة خاصة اسمها و اعہiلم8ء1اطهtإهS‏ لتسمح بالترتيب عند 
عرضها في جدول العرض.. لكن الغريب أن ميكروسوفت جعلت هذه الفئة 
خاصة» ولا يمكن للمبرمج استخدامها.. لهذا عليك أن تكتب كود هذه الفئة 
بنفسك في مشاريعك.. وستجد هذه الفئة في المشروع 5ععنطء1 01010012 
ضمن أمثلة هذا الكتاب» واستخدامها بسيط جداء فهي i‏ عامة Generic‏ 
6م10 يمكنك أن تخصصها لأي نوع تتعامل معه من البيانات» وليس عليك 
أكثر من أن ترسل إلى حدث إنشائها 0054101401 القائمة التي تريد أن 
تمنحها إمكانية الترتيب.. وستجدنا نستخدمها في المشروع على الصورة: 
Dim SortedList As New SortableBindingList(‏ 
Of PictureInfo)(Coins.PicsInfo. Values. ToList)‏ 
DataGridView1.DataSource = SortedList‏ 
حيث: 
- مكمآء ةعاط هو نوع البيانات المخزنة في القائمة» وهي فئة خاصة بي 
عرّفتها في المشروع.. هذا يوضح أنك تستطيع استخدام هذه الفئة مع أي نوعء 
سواء كان جزءا من إطار العمل أو خاصا بك. 
- 00105.2165110.177211165) هو مجموعة 0011601005 تحتوي على 
عناصر من النوع 101161510.. ولتحويلها إلى قائمة استخدمنا الوسيلة 
الإضافية 1001.16؛ وهي الوسيلة التي ستستخدمها في الغالب لإرسال القائمة 
إلى حدث إنشاء الفئة 156.][ع501186161910201» لتحويل المجموعات العائدة 
من نتائج استعلامات 00م1.] إلى قوائم. 
هذا كل شيء.. بعد هذا جعلنا مجموعة الربط القابلة للترتيب مصدر بيانات 
جدول العرض بإرسالها إلى الخاصية ..DataGridView.DataSource‏ 


:لاه 


الآن يمكنك ترتيب الجدول تبعا لأي عمود فيه بمجرد ضغط العمود بدون 
كتابة أي كود إضافي. 

ولا تسلني مرة أخرى لماذا لم تمنحنا ميكروسوفت هذه الإمكانية مباشرة ما 
دامت موجودة في إطار العمل وقررت أن تخفيها عناء فأنا لا أعلم! 


ملحوظة: 

في الفئة 156[ع 501181613912011 ستجد أنني حولت جزءا من الكود إلى 
تعليق في حدث إنشاء الفئة الداخلية :زع:1هم127)002عم220.. هذا الجزء 
من الكود سبب معي خطأ عندما كنت أتعامل مع نوع بيانات موروث من 
نوع آخرء لأن هذا الكود اعتبر أن الصفات الموروثة ليست خاصة بهذا 
النوع!!.. وقد وجدت أنه لا ضرورة لهذا الكود فحذفته» وعملت الفئة بعد 
ذلك على ما يرام! 








57 ف هل هو مرتبط بالبيانات 151(21421301120: 
تعيد 116 إذا كان العمود الحالي مرتبطا بمصدر بيانات. 


3 اسم خاصية البيانات :DataPropertyName‏ 

تحدد اسم العمود الأصلي في مجموعة البيانات» الذي يحفظ فيه العمود الحالي 
بياناته.. وتأخذ هذه الخاصية قيمته تلقائيا عند ربط جدول العرض بجدول في 
مجموعة البيانات» وإن كان باستطاعتك تغيير قيمة هذه الخاصية يدويا لربطها 
بأي عمود تريده» أو أي عنصر بيانات. 

لاحظ أن ضغط رأس العمود في جدول العرض لترتيب صفوفه» قد يؤدي إلى 
محو قيم خانات بعض الأعمدة.. فترتيب جدول العرض يودي إلى إعادة 
إنعاش الصفوفء وهذا يؤدي إلى ضياع قيم الخانات غير المرتبطة بمصدر 
بيانات عع50111 12033 بينما تقوم الخانات المرتبطة بمصدر البيانات بإعادة 
طلب القيم منه وعرضها مرة أخرى.. السبب في هذا هو أن جدول العرض 
مصمم لتوفير مساحة الذاكرة وتحسين الأداء» لهذا حينما يكون مرتبطا 
بمصدر بيانات أو يعمل في الوضع الافتراضي ل0 1M‏ ںا۲ ۰۷ لا يملأ كل 
الخانات بالبيانات» ولكنه يرسم مجموعة من الخانات مناسبة لمساحة العرض› 
ويحضر القيم من مصدر البيانات كلما احتاج إلى إنعاش الخانات المعروضة 
(عند تحريك المنزلق لعرض خانات جديدة» أو عند ترتيب الصفوفء أو عند 
اختفاء النافذة وإعادة عرضها.. إلخ).. لكن المشكلة تحدث حينما تضيف بعض 
الأعمدة غير المرتبطة بمصدر بيانات وتملأها باستخدام الكودء أو تترك 
للمستخدم ملئها بنفسه» فعند ترتيب الصفوف تفقد خانات هذه الأعمدة قيمها! 


هلاه 











ويمكنك حل هذه المشكلة بالتأكد من ربط جميع الأعمدة بمصدر البيانات.. 
طبعا من غير العملي إضافة أعمدة في قاعدة البيانات 172426356 مقابلة لهذه 
الأعمدة» فالبيانات التي تعرضها في الغالب تكون بيانات مستنتجة أو محسوبة 
أو مجرد 01601860 يؤدي وظيفة معينة» أو ترقيم أو ما شابه» ومن العبث 
حفظ هذه البيانات .فى قاهدة الفا على نياب زياد حهميا بلا مقادل . فنا 
الحل إذن؟ 

الحل هو إضافة خاصية جديدة في الفئة التي تمثل مصدر البيانات مثل الفئات 
الخاصة بمجوعة البيانات محددة النوع 10225614 60م:15.. لا تفعل هذا في 
الملف المولد تلقائيا 6600626121460 م411 (الذي ينتهي اسمه بالكلمة 
.همع زوع) لأن أي شيء تكتبه في هذا الملف سيكون عرضة للضياع.. 
ولكن اضغط بزر الفأرة الأيمن على اسم الفئة في مخطط مجموعة البيانات 
+5 ؛ واضغط الأمر 0006 77/161 لعرض الملف الخاص بامتداد هذه 
الففة ووهإاC‏ 1 وأضف إليه خاصية عامة 
Pubic Property‏ لتربط بها العمود الخاص بك. 

لاحظ أن هذه الخاصية لن تظهر ضمن خصائص الكائن في نافذة مصادر 
البيانات 50101065 12348 ولن تستطيع اختيار اسمها في نافذة الخصائص من 
ضمن خصائص مصدر الربط ع81201850110: لكن رغم هذا ما زلت 
تستطيع ربط العمود بها بوضع اسمها يدويا في الخاصية 
hata PropertyName‏ الخاصة به سواء في مصمم الأعمدة أو في الكود. 
الان يمكنك ترتيب صفوف جدول العرض دون خسارة بيانات هذا العمود. 


ملحوظة: 

يؤدي ترتيب جدول العرض أيضا إلى ضياع تنسيق جميع الخانات 
Sy‏ وعودتها إلى القيم الأساسية المحفوظة في الخاصية 
5-51 حل هذه المشكلة يحتاج جهدا 
كبيراء لأن الخانة تأخذ تنسيقها من عدة خصائص مختلفة مثل: 

. DataGridView.RowsDefultCellStyle - 

. DataGridViewRow.DefultCellStyle - 

. DataGridViewCell.CellStyle - 


وغيرها من الخصائص التي يمكنك الحصول على تأثيرها النهائي من خلال 
الخاصية DataGridViewCell.InheritedCe11Style‏ 

لهذا فإن محاولة حفظ قيم كل هذه الخصائص واستعادة تنسيق كل خانة بعد 
ترتيب الجدول عملية معقدة» خاصة إذا كان تنسيق الخانات يتغير أثناء تنفيذ 
البرنامج (كتغير لون خلفية أحد الصفوف عند اختيار قيمة معينة في إحدى 
خاناته)! 


كلاه 


وخ رقم العرض :12(1571331206: 
تقرأ أو تغير الموضع الذي يظهر فيه العمود الحالي في جدول العرض.. هذا 
لا يؤثر في شيء على ترتيب العمود في مجموعة الأعمدة» والذي توضحه 
الخاصية عرع10)1]. 


عرض الفاصل :Divider Width‏ 
تقرأ أو تغير حجم الخط الذي يفصل العمود الحالي عن العمود التالي.. هذا 
الفاصل هو مساحة خالية تأخذ نفس لون أرضية جدول العرض» ورغم أنها 
تعتبر جزءا من العمود الحاليء إلا أنها لا تؤدي أية وظيفة من وظائفه» ما عدا 
العمل كفاصل شكلي. . والصورة التالية توضح تأثير وضع القيمة ٠١‏ في هذه 

الخاصية في العمود الأول: 


About | Phone CountryID 
71 











والقيمة الافتراضية لهذه الخاصية هي صفرء لهذا لا يوجد أي فاصل بين 
الأعمدة» ما عدا خطوط الشبكة العادية. 


7 خانة العنوان 1[ :H 4d er)‏ 
ضع في هل الخاصية كائن خانة عنوان العمود 
DataGrid ViewColumnHeaderCell‏ الذي يحمل خصائص رأس 

العفود الحالي..-وستتهر ف على هذه النئة بالتفضيل اقا 
ويمكنك استخدام هذه الخاصية لتغيير لون خلفية الخانة الرئيسية 
06[1 امل Hea‏ لأحد أعمدة جدول العرض.. مبدئيا يجب أن تغير قيمة 
الخاصية EnableHeadersVisualStyles‏ .7177 إلى «False‏ 
فلو كانت قيمتها 1716 فلن يكون هناك أي تأثير لو غيرت لون الخلفية في 
الخاصية ColumnHeadersDefaultCelIStyle‏ والخا د 
Row HeadersDefaultCelIStyle‏ والخاصية عار†S‏ الخاصة بالخانة 
الرئيسية للعمود أو الصف: 
Dgv1.EnableHeadersVisualStyles = False‏ 

بعد هذاء يمكنك أن تغير لون خلفية الخانة الرئيسية للعمود رقم > كالتالي: 

Dgv1.Columns(X).HeaderCell.Style.BackColor = Color.Red 
.1"01600101 ويمكنك تطبيق نفس الطريقة لتغيير لون النص‎ 





وجا نص العنوان Header Text‏ : 


/الاه 











تقرأ أو تغير النص الذي يظهر في خانة عنوان العمود الحالي. 


7 قالب الخانة :CellTemplate‏ 
ضع في هذه الخاصية كائن الخانة ۷1ew ٣11‏ 14ا 6ه)†هط الذي تريد 
افاتخدامه كالب هة نة الخاتاك التى تضاف إلى العمود خصائضيها. 


فط نوع الخانة 6م661115: 
تعيد كائن النوع عم:15» الذي يوضح نوع الخانة المستخدمة كقالب في 
الخاصية ع]12م7م061171.. لاحظ أن الخاصية 13]6م06111650© من النوع 
الفنة الأم 1(3]801101/160[11» بينما تعيد الخاصية ءم06111597 النوع 
الفعلي المشتق من هه الفئة الأم.. وسنتعرف اد 
1017161 ومشتقاتها لاحقا. 


كما تلك هذه الف الوسيلة الثالية: 


#> معرفة العرض المفضل :GetPreferred Width‏ 
تعيد أنسب عرض للعمود تبعا للمواصفات المطلوبة» وهي تأخذ معاملين: 

- إحدى قيم المرقم «DataGridViewAutoSizeColumnMode‏ 
تحدد طريقة الحجم التلقائي للعمود. 

- معامل منطقي» > إذا جعلت قيمته 1:06» فسيتم تقدير العرض المناسب 
للعمود بافتراض أن ارتفاع خاناته سيظل ثابتاء أما إذا جعلته 1:2156: 
فسيدخل في الاعتبار إمكانية تغيير ارتفاعات الصفوف» وهل هناك 
التفاف لأسطر الخانات م718 717010 أم لاء حيث ستتم المحافظة على 
النسبة بين عرض العمود وارتفاع خاناته. 


والفئة مدصن01 12320110171610 تعمل كفئة أم لكل من الفئات التالية: 
-١‏ عمود مربعات النصوص 162130720011112 102128001101716557. 

؟- عمود الأزرار .DataGridViewButtonColumn‏ 

"- عمود مربعات الاختيار .DataGridViewCheckBoxColumn‏ 
5 - عمود القوائم المركبة .DataGridViewComboBoxColunan‏ 

5- عمود الصور .DataGridViewImageColumn‏ 

.DataGridViewLinkColumn عمود الوصلات‎ -٦ 
ولكن الأمر لا يتوقف عند هذه الأنواع» فبإمكانك وراثة هذه الفئة لإنشاء أعمدة‎ 
تعرض خاناتها أي أداة أخرى من أدوات الويندوز.. ولو ضغطت الزر "عمود‎ 
تواريخ" في المشروع 5ء15/70: 103201100011110 فسيضاف إلى جدول العرض‎ 

عمود تعرض كل خانة من خاناته أداة اختيار التاريخ .DateTimePicker‏ 


مناه 


1 1 وريه 1 1 كم ريك ث1 1 بكم جيك‎ Iifeafre «a 


كح ريك ث1 1 جيك 1 1 Iie af T+‏ س 1609/2003 


fear. 


1١17-5‏ الجمحة الخميس الاربجاء الخلاتاء الاثنين الاحد السيت 


29 30 31 1 2 3 3 1 1 الريك‎ e .q 
1 1 + كم ء ريك‎ 





ولو فتحت متصفح المشاريع» لوجدت فيه فئة اسمها 031620231001110 ترث 
الفئة م ..Data6 r4V 1ew €1 um‏ وكود هذه الفئة 
بسيط للغاية» فهي تستبدل 071106 عنصرين فقط 
من عناصر الفئة الأم: حدث الإنشiء«ء New‏ 
والخاصية ع126م7م06111: وذلك للتعامل مع 
النوع الجديد لخانات هذا العمودء» وهو فئة جديدة 
أنشأناها بأنفسنا أيضا اسمها [216006206[1© 
مهمتها عرض أداة اختيار التاريخ.. وسنتعرف على 
فكرة هذه الفئة لاحقا. 

وبنفس الطريقةء أمكننا إنشاء عمود تعرض كل خانة 
فيه شجرة سع ۷1ء٥1۲٠‏ ويمكنك إضافة هذا العمود 
إلى الجدول بضغط الزر "عمود أشجار" في نفس 
المشروع. 

لاحظ أن هذه الشجرة غير عملية» فهى تظهر 
بكاملها داخل الخانة» وهو ما يحتاج إلى جعل 
مساحة الخانة كبيرة لضمان ظهور فروع الشجرة 
بشكل مقرل ريمكفك بحل هذه المشكلة بالنتكداء 
شجرة منسدلة» وقد شرحنا فكرتها في كتاب "برمجة 
نم لذج الوين دوز" في المشروع 
:0101)_, على كل حالء يمكنك إضافة هذا النوع من الأعمدة إلى 
جدول العرض بضغط الزر "عمود أشجار منسدلة". 























اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 


4/اه 









































واحفظ والدتي وبارك في عمرها 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 






للكت 


42 عمود مريعات النصووص 
DataGrid ViewTextBoxColumn Class‏ 


هذه الفئة ترث الفئة ردصu‏ €1 (t6۲: ۷1ew‏ وهي تعمل كعمود خاناته من 
النوع | »DatG rid View extBoxCe[‏ وهي خانات تعرض لافتات» وعند 
تحرير أي خانة منهاء فإنها تعرض مربع نص.. ويمكنك ضغط الزر 
"عمود النصوص" في المشروع وعم/10215نا1 10330011000 لإضافة عمود من 
هذا النوع إلى جدول العرض. 


ويعتبر عمود مربعات النص النوع الافتراضي الذي يضيفه جدول العرض عند 
ربطه بمصدر بيانات. 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخاصية التالية: 


وخ أقصى طول للمدخلات :MaxInputLength‏ 
تحدد أقصى عدد من الحروف تقبله كل خانة في العمود.. والقيمة الافتراضية لهذه 
الخاصية هي ٠۲۷٦۷‏ ولو جعلتها صفرا فهذا يعني السماح للمستخدم بكتابة الحد 
الاقصى من الحروف» وهو يتجاوز ۲ مليار حرف. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


4 فة عمود الأزرا 
0111111155 )110101111711011 


هذه الفئة ترث الفئة 1(312011017/16000111: وهي تعمل كعمود خاناته من 
النوع 11ع1021201101/168100000» وهي خانات تحمل كل منها زرا 810400 
يمكن للمستخدم ضغطه.. ويمكنك ضغط الزر "عمود أزرار" في المشروع 
05 لإضافة عمود من هذا النوع إلى جدول العرض. 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخصائص التالية: 


النص )بد1: 
تقرا أو تغير النص الافتراضي المعروض على جميع الأزرار الموجودة في 
خانات العمود. 


3 استخدام نص العمود لقيمة الزر :UseColumnTextForBut(on Value‏ 
إذا جعلت قيمة هذه الخاصية 172156 (وهي القيمة الافتراضية)» فلن يظهر 
النص الموجود في الخاصية 1٠×٤‏ على أزرار خانات العمود» وستكون كل 


| طريقة العرض المسطح 112]5)916: 
تحدد طريقة عرض الزرء وهي تأخذ إحدى قيم المرقم 1135671 التالية: 


0 اإايظهر الزر مجسما بالطريقة القياسية المعتادة ثلاثية الأبعاد.. 
هذه هي القيمة الافتراضية. 

۴ إيظهر الزر مسطحاء ويتغير لون خلفيته عند مرور الفأرة فوقه 
وعند ضغطه. 

منام20 يظهر الزر مسطحاء لكن عند المرور فوقه بالفأرة يبرز إلى 
أعلى ويصير مجسما. 

على جهازه. 


























42 فئة عمود مربعات الاختيار 
DataGrid ViewCheckBoxColumn Class‏ 


هذه الفئة ترث الفة وص »Data6 r View €1 u‏ وهي تعمل كعمود خاناته من 
النوع DataGrid ViewCheckBoxCe[|‏ وهي خانات تحمل مربع اختيار 
161801 .. ويمكنك ضغط الزر "عمود مربعات اختيار" في المشروع 
5 لإضافة عمود من هذا النوع إلى جدول العرض. 
ولحدث إنشاء هذه الفئة صيعتان: 

-١‏ الصيغة الأولى بدون معاملات. 

؟- والصيغة الثانية تستقبل معاملا منطقيا ه80016» يتم إرسال قيمته إلى 

الخاصية 1116651216 التي سنتعرف عليها بعد قليل. 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخصائص التالية: 


طراز العرض المسطح 16:ج)11365: 
مماثلة لتلك الخاصة بعمود الأزرار. 


وخ ثلاثي الحالة :ThreeState‏ 

إذا جعلت قيمة هذه الخاصية ع1" فسيكون مربع الاختيار ثلاثي الحالة 
(متضمنا الحالة الوسيطة غير المحددة مأهمنصإم†ملم]).. هذا معناه أن 
المستخدم إذا ضغط المربع مرة فستوضع به علامة الاختيار»ء وإذا ضغطه 
مرة أخرى فسيصير في الحالة الوسيطة (بعلامة اختيار غائمة) وإذا ضغطه 
مرة ثالثة فستزال علامة الاختيار. 

أما إذا جعلت قيمتة هذه الخاصية 721596 (وهذه هي القيمة الافتراضية)» 
فسيكون لمربع الاختيار حالتان فقط (Checked - Unchecked)‏ وهذا 
معناه أن المستخدم إذا ضغط مربع الاختيار مرة فستوضع به علامة الاختيارء 
وإذا ضغطه مرة أخرى فستزال منه هذه العلامة. 


3 القيمة الخاطنة ue‏ 1ھ ۷ءء[ے۴: 
تستقبل كائنا ٤ع‏ زط0 يحتوي على القيمة المناظرة لحالة عدم الاختيار 
Unchecked‏ . 


القيمة الصحيحة [ue‏ e۷ں٣آ:‏ 
تستقبل كائنا )زط0 يحتوي على القيمة المناظرة لحالة الاختيار إء)ءءط٤.‏ 


"ره 


القيمة غير المحددة :IndeterminateValue‏ 
تستقبل كائنا ٤ء‏ زا0 يحتوي على القيمة المناظرة للحالة الوسيطة غير 
المحددة .Indeterminate‏ 


ك اس تخدام الخصسائص False Value‏ و TrueValue‏ 
و Value‏ eterminateل[‏ إذا كان العمود الحالي مرتبطا بمصدر بيانات.. افرض 
على سبيل المثال أن لديك مصدر بيانات يحتوي على ثلاثة أرقام هي 
OY oI oo‏ وقمت بربطها بعمود مربعات اختيار.. في هذه الحالة افعل ما يلي: 
- ضع في الخاصية 131961721116 القيمة ٠‏ لتخبر العمود أن الخانات 
المناظرة للقيمة ٠‏ في مصدر البيانات لن توضع بها علامات الاختيار. 
> لعفي الخاصية 100657116 القيمة ١‏ لتخبر العمود أن الخانات 
المناظرة للقيمة ١‏ في مصدر البيانات ستوضع بها علامات الاختيار. 
- ضع في الخاصية 1206]6110122165/2106 القيمة ۲ لتخبر العمود أن 
الخانات المناظرة للقيمة ۲ في مصدر البيانات ستوضع بها علامات اختيار 
غائمة دلالة على أنها حالة وسيطة غير محددة. 


ولكن: كيف يمكنك أن تعرف أن المستخدم غير حالة الاختيار 0160160 في أي 
خانة في عمود من هذا النوع موضوع في جدول العرض؟ 
عندما يضغط المستخدم مربع الاختيار في أي خانة في هذا العمودء ينطلق الحدث 
DataGridView .CellContentClick‏ الخاص بجدول العرض.. في هذا 
الحدث افعل ما يلي: 
- تأكد أن الخاصية 0011111111062.»© تشير إلى رقم العمود 
7111001 لا لأن هذا الحدث ينطلق عند 
ضغط خانات أعمدة من أنواع أخرى. 
- احصل على الخانة الحالية التي تسببت في إطلاق هذا الحدث باستخدام 
الخاصية ..Data GridView .CurrentCe[1‏ أو يمكنك استخدام التعبير 
التالي للحصول على هذه الخانة (افترض أن اسم جدول العرض 07ع(1): 
Dim Cell = Dgv.Rows(e.RowIndex).Cells(e.ColumnIndex)‏ 
آنا أفضل الطريقة الأخيرة» ففي بعض الأحيان يمكن أن تشير الخاصية 
CurrentCell‏ إلى خانة محددة أخرى» بينما ضغط الخانة التى أطلقت 
الحدث ما زال لم يجعلها الخانة الحالية.. لهذا إذا وجدت رقم الصف والعمود 
في البيانات المرافقة لأي حدث من أحداث جدول العرضء فالآمن أن 
تستخدمها! 


55 


مغادرة الصف ا رحد نيه فى هدو العرض!!.. الخدعة هنا ف ا 
الخاصية ع11[ه057ع10216ه11.58016010[ع0 بدلا متها 
If CBool(Cell.EditedFormattedV alue) then‏ 
("ثم اختيار هذه الخان' MsgBox)‏ 
End If‏ 
ولا تحاول استخدام الحدث أعع ,2طا٣‏ عںاه11۷ءC‏ (فكما قلنا فإن الخانة لا تحدث 
قيمتها إلا بعد مغادرة الصف)!!.. أيضا لا تحاول استخدام معالج للحدث 
4 اسلخاص بمربع الاختيار 026186012 الموجود في هذه 
الخانةء ولكن لم أستطع» لأن هذه الخانات لا تتسبب في إطلاق الحدث 
DataGridView.EditingControl]Showing‏ | 
كما أني أنصح بالتالي: 
إذا كان العمود DataGridView CheckBoxC‌olu1‏ مرتبطا بمصدر بيانات» 
فليس عليك أن تقلق بشأنه» فهو سيحدث سجلات مصدر البيانات عع122]2501 
بطريقة صحيحة طبقا للخانات التي اختارها المستخدم أو أزال منها الاختيار.. أما 
إذا لم يكن هذا العمود مرتبطا بمصدر بيانات» وكان عليك أداء وظيفة معينة تبعا 
لقيم خاناته» فالحل الأسهل والأضمن هو أن تنفذ هذه الوظيفة مرة واحدة في إجراء 
اسمه 5 مثلاء» يتم استدعاؤه عندما يضغط المستخدم زر الحفظ أو 
عندما يحاول إغلاق النافذة وتسأله إن كان يريد حفظ التغييرات.. في هذا الإجراء 
كل ما ستفعله هو المرور عبر كل صفوف جدول العرض» وفحص قيمة كل خانة 
في ةا العف وة (افت رض أت هة العمب يوق 
رقم 1)» واتخاذ الفعل المناسب تبعا لحالتهاء على الصيغة: 
Dgv.EndEdit( )‏ 
For Each Row As DataGridViewRow In Dgv.Rows‏ 


If CBool(Row.Cells([).Value) Then 
' الوظيفة الخاصة بكون الخانة مختارة‎ 


Else 
' الوظيفة الخاصة بكون الخانة غير مختارة‎ 
End If 
Next 


لاحظ استدعاءنا للوسيلة 20117016 في بداية الكود لإنهاء تحرير أي خانة ما زالت 


42 فة عمود الصو 
DataGrid ViewImageColumn Class‏ 


هذه الفئة ترث الفئة »Data6 r View €1 um‏ وهي تعمل كعمود خاناته من 
النوع »DataG rid ViewImageء٣ e11‏ وهي خانات تعرض كل منها صورة.. 
ويمكنك ضغط الزر "عمود الصور" في المشروع DataGridColumnTypes‏ 
لإضافة عمود من هذا النوع إلى جدول العرض. 
ولحدث إنشاء هذه الفئة صيعتان: 

-١‏ الصيغة الأولى بدون معاملات. 

؟- والصيغة الثانية تستقبل معاملا منطقيا ه80016» يتم إرسال قيمته إلى 

الخاصية 772116581610015 التي سنتعرف عليها بعد قليل. 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخصائص التالية: 


وخ الوصف :Description‏ 
ضع في هذه الخاصية نصا يصف الصور أو الأيقونات الموجودة في خانات 
العمود. 


وع القيم أيقونات :ValuesAreIcons‏ 
إذا جعلت قيمة هذه الخاصية عuإ1»‏ فستعرض خانات العمود الأيقونة 
الموجودة في الخاصية رزمن].. أما إذا جعلتها 72156 (وهي القيمة 
الافتراضية)» فستعرض خانات العمود الصورة الموجودة في الخاصية 
.Image‏ 


وجا الأيقونة :رم ح1: 
ضع في هذه الخاصية كائن الأيقونة 0ج1 الذي تريد عرضه في خانات 
العمود عندما تكون للخاصية 015ح1ع4316/و116ج7؟ القيمة 1111 . 


وخ الصورة 1212866: 
ضع في هذه الخاصية كائن الصورة 1021386 الذي تريد عرضه في خانات 
العمود عندما تكون للخاصية 05ح1ع2لكروع11ج17 القيمة ع1"215. 


و- مخطط الصورة 11125©12(:01116: 
تحدد طريقة عرض الصورة في خانات العمودء وهي تأخذ إحدى قيم المرقم 





33/014آ11ع0ع8 مآ 122201101716 التالية: 


5 | القيمة غير محددة (متروكة لكل خانة على حدة). 
Normal‏ يتم عرض الصورة كاملة في منتصف كل خانة.. هذه هي القيمة 


الافتراضية. 


طStretc‏ | يتم مط الصورة لتلائم عرض وارتفاع كل خانة.. هذا معناه أن 


الصورة ستملا كل مساحة الخانة» ولكن هذا قد يؤدي إلى 


ص700 يتم تكبير أو تصغير الصورة لتلائم عرض أو ارتفاع الخانة» مع 


المحافظة على النسبة الأصلية بين ارتفاع الصورة وعرضهاء 








لاحظ أن جدول البيانات في الوضع الافتراضي يعرض عمود طابع الوقت 
rimeta&mp‏ تلقائيا في عمود صورء لمجرد أن هذا العمود يحمل بيانات ثنائية.. 
وقد رأينا كيف سبب لنا هذا مشاكل كثيرة فيما سبق. 

ولحل هذه المشكلة» عليك تغير نوع هذا العمود بعد ربط جدول العرض بمجموعة 
البيانات.. لفعل هذا في وقت التصميم» اتبع الخطوات التالية: 


حدد جدول العرض على النموذج وافتح نافذة الخصائص. 
اضغط الرابط وصسصدآاه٣‏ 2016 الموجود في الجزء السفلي من نافذة 
الخصائص.. سيفتح هذا نافذة تحرير مجموعة الأعمدة. 
حدد عمود طابع الوقت» لعرض خصائصه في الجزء الأيمن من النافذة. 
حدد الخاصية 6م/00110015) تحت الشريط مبعزوء(1: واضغط زر 
الإسدال« واختر من القائمة النوع DataGrid TextBoxColumn‏ بدلا 
من النوع 011220 1031301101113560.. هذا سيمنع الأخطاء التي تحدث 
بسبب محاولة رسم البيانات الثنائية كصورة.. لاحظ أن العمود لا يملك 
فعليا خاصية اسمها مم ر 1٣ں‏ آه)» وما يفعله المصمم هو حذف العمود 
القديم» وإنشاء عمود جديد من النوع الذي اخترته في هذه الخاصية مع نسخ 
باقي خصائص العمود القديم إلى العمود الجديد.. لهذا لا تستطيع تغيير نوع 
العمود من الكودء إلا بحذفه وإنشاء عمود جديد. 
أو يمكنك أن تضع القيمة ع7215 في الخاصية 17151616 لإخفاء العمود 
وحل المشكلة من جذورهاء وهذا ما فعلناه من الكود في المشاريع السابقة: 
DGAuthors.Columns("'"RowVersion"). Visible = False‏ 

















4 فئة عمود الوصلات DataGridViewLinkColumn Class‏ 


هذه الفئة ترث الفئة 1(3120110171657000111: وهي تعمل كعمود خاناته من 
النوع »DataG rid View Link ٣ e11‏ وهي خانات تعرض كل منها رابطا (وصلة) 
خمi[..‏ ويمكنك ضغط الزر "عمود الوصلات" في المشروع 
170-65 وإضافة عمود من هذا النوع إلى جدول العرض. 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخصائص التالية: 


7 النص )بر 1: 
تفرأ أو تغير نص الوصلة المعروضة في خانات العمود. 


:UseColumnTextForLinkValue استخدم نص العمود كقيمة للوصلة‎ E 
إذا جعلت قيمة هذه الخاصية 12196 (وهي القيمة الافتراضية)» فلن يعرض‎ 
النص الموجود في الخاصنية )ج16 کر صلات في كاناك العمود» وستكون كل‎ 


ال سلوك الرابط :LinkBehavior‏ , 
تحدد كيف يبدو شكل الرابط» وهي تأخذ إحدى قيم المرقم :LinkBehavior‏ 


ên derine‏ aysسWا‏ | الرابط تحته خط دائما. 

101110 الا يوضع خط تحت الرابط إلا حينما يمر فوقه 
مؤشر الفأرة. 

Never Underline‏ | لا يوضح خط تحت الرابط مطلقا. 

Systeme ut‏ | خيارات متصفح الإنترنت ونظام الويندوز هي التي 
توضح كيف يبدو الرابط. 








“و نون الرابط -ر0010ع1,101- 
تحدد لون الروابط المعروضة في العمود.. وفي الوضع التلقائي يكون هذا 
اللون هو الأزرق. 




















7 لون الرابط الفعال :ActiveLinkColor‏ 
تحدد لون الرابط أثناء ضغطه بالفأرة.. في الوضع التلقائي يكون هذا اللون هو 
الأحمر. 


اننا لون الرابط المُزار :Visited LinkColor‏ 
تحدد لون الرابط بعد أن يضغطه المستخدم.. في الوضع التلقائي يكون هذا 
اللون هو الأحمر الغامق. 

وخ تتبع حالة الزيارة :TrackVisitedState‏ 
إذا جعلت قيمة هذه الخاصية 116 (وهي القيمة الافتراضية)» فسيتغير لون 
الرابط بعد ضغطه. ليأخذ اللون المحدد في الخاصية .VisitedLinkColor‏ 


وقد استخدمنا عمود الوصلات في المشروع 011540101022564 لعرض وصلة 
"عرض درجات الطالب". 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


فئة عمود القوائم المركبة 


DataGrid ViewComboBoxColumn Class 


هذه الفئة ترث الفئة وص »Data6G r View €1 u‏ وهي تعمل كعمود خاناته من 
النوع DataGrid ViewComboB 0x٣ e11‏ وهي خانات تحمل قوائم منسدلة 
Boxes‏ b0ص€0m..‏ ويمكنك ضغط الزر "عمود قوائم مركبة" في المشروع 
65 وبولإضافة عمود من هذا النوع إلى جدول العرض. 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخصائص التالية: 


7 طراز العرض المسطح 112)56916: 


وخ عرض القائمة المنسدلة :DropDown Width‏ 

تحدد عرض القائمة المسندلة.. والقيمة الافترضية لهذه الخاصية هي ١‏ ولا 
تقبل أقل منهاء لكن عليك أن تلاحظ أن وضع أي قيمة أصغر من عرض 
العمود في هذه الخاصية سيجعلها بدون تأثيرء لأن القائمة المنسدلة يمكن فقط 
أن تكون مساوية لعرض العمود أو أكبر منه!.. هذا يضمن لك أن القائمة 
المنسدلة ستأخذ نفس عرض العمود تلقائيا لو قام المستخدم بزيادة عرضه.. 
هذا معناه أن عرض القائمة المنسدلة يحسب فعليا من العلاقة التالية: 

Actual Width = Max (DropDownWidth, Col Width) 


وخ إكمال تلقائي :AutoCom plete‏ 
إذا جعلت قيمة هذه الخاصية م (وهي القيمة الافتراضية)» فسيتم اقتراح 
التكملة المتاسبة للدروف التي يكتيها المشتخدم في القائمة المركية. 


“و مصدر البيانات عع:1دا72220350: 
ضع في هذه الخاصية الكائن الذي سيعمل كمصدر بيانات» لاستخدامه في 
ملء القائمة المركبة بالعناصرء مثل اسم جدول الدول 0131211165 0: 
Col.DataSource = 105. 1'2125) "60011111165" (‏ 
لاحظ أن العمود في هذه الحالة يتعامل مع مصدرين من مصادر البيانات: 
- مصدر بيانات جدول العرض نفسه (الذي يرتبط بجدول المؤلفين مثلا). 
- مصدر بيانات القائمة المركبة (الذي يرتبط بجدول الدول). 
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وخ عنصر العرض :Display Member‏ 
ضع في هذه الخاصية اسم عنصر البيانات» لعرض قيمته في القائمة المركبة.. 
مثل العمود N4٠‏ في جدول الدول: 
Col.DisplayMember = "Name"‏ 


ملحوظة: 

أو امستكدمت I‏ كمصكر TEE EG‏ الخاضية 
1 11 ففعناصر المصفوفة نفسها ستكون عناصر العرض» 
وهذا هو ما فعلناه عند وضع القيم في عمود القوائم المركبة في المشروع 
171155 لاحظ وأنت تجرب المشروع أن ضغط زر 
إسدال القائسة لا يعمل إلا إذا كاذك الخادة التى يوحن فيها محندة ارلا لهذا 
فإن أول ضغطة ستعمل على تحديد الخانة» وثاني ضغطة ستسدل القائمة. 








وخ عنصر القيمة :Value Member‏ 

تعمل هذه الخاصية مع الخاصية ع6117271210م12343210 الموروثة من فئة 
العمود» للربط بين جدولين.. مثلا: في المشروع 0121617110152م17] حذفنا 
العمود (00111/11© وأضفنا بدلا منه عمود قوائم مركبة يعرض أسماء 

الدول» بدلا من أن نعرض للمستخدم رقم الدولة التي ينتمي إليها المؤلف: 
حذف عمود أرقام الدول ' 
DataGridView1.Columns.Remove("CountryID'")‏ 
تعريف عمود قوائم منسدلة ' 
Dim Col As New DataGrid ViewComboBoxColumn( )‏ 
Col.Name = "Country"‏ 
ملء العمود بأسماء الدول ' 
Col.DataSource = Ds.Tables("Countries"")‏ 
Col.DisplayMember = "Name"‏ 
إضافة العمود إلى جدول العرض ' 
DataGridView1.Columns.Insert{@2, Col)‏ 
هذا سهل ومفهوم» فالقائمة الآن مرتبطة بجدول الدول وتعرض قيم الحقل 
مصه.. لكن المشكلة أن المستخدم لو اختار الدولة مصر مثلاء فعلينا وضع 
رقم هذه الدولة (وهو )١١‏ في الحقل (0/11© في جدول المؤلفين» وهذا 

قد يحتاج إلى كتابة بعض الكود يدويا. 

لا تقلق.. لن نكتب أي كود لفعل هذا.. كل ما علينا هو إخبار القائمة المركبة 
أنها ستحفظ قيمة العمود 10 التابع لمصدر بيانات العمود الحالي 
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(وهو هنا جدول الدول)؛ في العمود (0011415:11) التابع لمصدر البيانات 
جدول العرض كله (وهو هنا جدول المؤلفين)» وذلك كالتالي: 

Col.ValueMember = "ID" 

Col.DataPropertyName = "CountryID" 


57 ف العناصر ومر م)]: 
تعيد مجمو عة من النو ع «0ناءع]اه٣1ءعزطا0»‏ وهي مجموعة تمثل الواجهة 
+151 معرفة داخل الفئنة ›DataGridViewComboBoxCe1]|‏ وكل 
عنصر من عناصرها من النوع ء٥‏ ا0ء وهي تحتوي على عناصر القائمة 
المركبة.. لاحظ إن استخدام الخاصية 1234850106 يلغي عمل الخاصية 
5. مثلا: لو أضفت بعض العناصر إلى المجموعة 165015 ثم وضعت 
مصدر بيانات في الخاصية ع1(34350110» فستعرض القائمة المنسدلة 
عناصر مصدر البيانات وتتجاهل العناصر التي أضفتها إلى الخاصية 
35 أما إذا وضعت مصدر البيانات في الخاصية 17212501106 أولا ثم 
حاولت إضافة بعض العناصر إلى الخاصية 75ه:1 فسيحدث خطأ في 
البرنامج! ۰ 


وخ طريقة العرض 1215012(3510016: 
تحدد كيف تظهر القائمة المركبة في خانات العمود» وهي تأخذ إحدى قيم 
المرقم DataGrid ViewComboBoxDisplayStyle‏ التالية: 

ComboBox‏ حتى عندما لا تكون الخانة محددة» ستظل تعرض 
القائمة الموكية. 
| عندما لا تكون الخانة محددة» ستعرض زر إسدال 
القائمة المركبة بمفرده. 
Nothing‏ عندما لا تكون الخانة محددة» فإنها لا تعرض 
القائمة المركبة إلا في الخانة المحددة فقط. 











۹۲ 

















3 طريقة عرض الخانة الحالية فقط :DisplayStyleForCurrentCe1IOnly‏ 
إذا جعلت قيمة هذه الخاصية عں إ٠‏ فستؤثر الخاصية 101513325616 على 
الخانة المحددة في العمود الحالي فقط دون باقي خانات العمود.. والقيمة 
الافتراضية لهذه الخاصية هي ع1"215. 
لاحظ أن وضع القيمة عمذطغ710 في الخاصية 1(150133:5616 مع وضع 
القيمة عں إ1 في الخاصية DisplayStyleForCurrentCe11Only‏ سيخفي 
القائية افر ك وول ادال هن كل خانات العفوة يبعا فى ذلك الحا 
المحددة!.. في هذه الحالة على المستخدم نقر الخانة المحددة مرتين بالفأرة 
لإظهار القائمة المركبة! 


وخ أقصى عدد من العناصر المسدلة :MaxDropDownIt(ems‏ 
تقرأ أو تغير عدد العناصر التي يمكن عرضها في القائمة المندسلة بدون 
الحاجة إلى منزلق رأسيء أما إذا زاد عدد العناصر عن هذا العدد فسيظهر 
منزلق رأسي ليتيح للمستخدم عرض باقي العناصر.. وتقبل هذه الخاصية قيمة 


وج مرتبة 0ع5901:1: 
إذا جعلت قيمة هذه الخاصية 1:16؛ فسيتم ترتيب عناصر القائمة المرتبة 
أبجديا. 

ملحوظة: 


الخصيائص السافة فوكر على حميم القواك المركية الموجموىة فى كل بكانات 
العمود» كما تؤثر على الثائمة المركبة الخاصة بقالب الخانة الموجود في الخاصية 
1316 م6111 .. لكن يظل بإمكانك تغيير خصائص القائمة المركبة لكل خانة 
على حدة» كما سنرى لاحقا. 


o۹۲ 














9 فة مفو دة صفوف جدول العرض 
DataGrid ViewRowCollection Class‏ 


هذه المجموعة تمثل الواجهة 11.156» وهي تحتوي على عناصر من نوع صف 
جدول العرض .DataGrid View Row‏ 

ويستقبل حدث إنشاء هذه الفئة كائن جدول العرض :10308011017167 الذي تنتمي 
إليه المجموعة.. لكنك لا تحتاج إلى إنشاء نسخة جديدة منهاء لأناك تتعامل مع 
مجموعة صفوف جدول العرض من خلال الخاصية 10175 الخاصة به. 


وإضافة إلى العناضر التقليدية للمجموعات» تمتلك هذه الفثة الؤسائل الثالية: 


> إضافة 400: 
تضيف صفا جديدا إلى جدول العرض وتعيد عددا صحيحا يمثل موضعه في 
مجموعة الصفوفء ولها الصيغ التالية: 1 
٤‏ الصيغة الأولى بدون معاملات» وهي تضيف صفا له القيم الافتراضية. 


- الصيغة الثانية تستقبل كائن الصف wR 0w‏ ع۲14۷1 D246‏ لإضافته 


إلى المجموعة. 


2 | ب 4 الثالثة . تقب ۰ فة کائنات «Object Array‏ وتن 5 صفا 


جديدا وتضع في خاناته قيم هذه المصفوفة بنفس الترتيب» وتضيفه إلى 
جدول العرض 


وتتسبب هذه الوسيلة في حدوث خطأ في البرنامج في الحالات التالية: 


إذا لم تكن هناك أية أعمدة في جدول العرض. 

إذا كان عدد خانات الصف أكبر من عدد أعمدة الجدول. 

إذا كان الصف الجديد مثبتا ع18102» لكنه سيضاف بعد صفوف غير 

إذا كان جدول العرض يقوم بتحديد كل خاناته في تلك اللحظة أو يزيل 

تحديدها. 

إذا تم استدعاء الوسيلة ل۸ من داخل أي من الأحداث التالية: 

CellEnter, CellLeave, CellValidating, CellValidated, 
RowEnter, RowLeave, Row Validated, Row Validating. 

إذا كان جدول العرض في الوضع الافتراضي 

.(DataGridView. VirtualMode = True) 

اذا كان حول ارصن مر قط سضر اتات 

.(DataGridView.DataSource <> Nothing) 


6: 


لاحظ أن الصف الجديد الذي أضفته لا يتم ترتيبه ضمن صفوف الجدول» ولو 
أردت أن يوضع في الترتيب الصحيح» فعليك استدعاء الوسيلة 
71 في الحدث DataGrid View.RowsAdded‏ 
لإعادة ترتيب صفوف الجدول. 


# إضافة نسخة رم0 006 4: 
تستقبل رقم ضف في مجموعة الصفو ف» حيث تنسخ صفا جديدا مماثلا له 
ولتضبيفة إلى الم جمو عة وتعيد موضع إضافته. 


# إضافة نسخ وءزم40060: 
مماثلة للوسيلة السابقة» إلا أنها تنسخ من الصف الموضح رقمه في المعامل 
الأول» عدد النسخ الموضح في المعامل الثاني» وتضيف هذه الصفوف 
المنسوخة إلى المجموعة» وتعيد رقم آخر صف تمت إضافته. 


# إدراج :Insert‏ 
تدرج صفا أو أكثر في موضع معين داخل مجمو عة الصفوف.. ولهذه الوسيلة 
عدة صيغةء كلها تشترك في أن معاملها الأول يستقبل الموضع الذي سيتم 

إدراج الصف فيهء وتختلف في المعامل الثاني كما يلي: 

-١‏ يستقبل المعامل الثاني للصيغة الأولى عدد الصفوف الجديدة التي سيتم 
إدراجها في المجموعة. 

؟-.يستقبل المعامل الثائي للضبيغة الثافية مضفوفة كائنات 
Ary‏ أن ءزط0» حيث يتم إنشاء صف جديد وإضافته إلى موضع 
الإدراج» ووضع قيم المصفوفة في خانات هذا الصف بنفس الترتيب. 

۳- يستقبل المعامل الثاني للصيغة الثالنة كائن الصف 
11077 المراد إدراجه. 


#ا> إدراج نسخة 7م1:))0ء105: 
تنسخ صفا من المجموعة وتدرجه في موضع معين فيهاء ولها معاملان: 
- المعامل الأول يستقبل رقم الموضع المراد إدراج الصف الجديد فيه. 
- المعامل الثاني يستقبل رقم الصف المراد نسخه. 


> إدراج نسخ :InsertCopies‏ 
مشابهة للوسيلة السابقة» إلا أنها تزيد عليها بمعامل ثالث» يستقبل عدد النسخ 
التي سيتم إنشاؤها من الصف الموجود في الموضع المحدد في المعامل الثاني» 


هوه 


ب 


ف 


الأول. 


معرفة حالة الصف :GetRowState‏ 

تخبرك بحالة الصف الذي أرسلت إليها رقمه في المجموعة كمعامل.. وهي 
تعيد إحدى قيم المرقم وع0145126ع12312011017165:111»20 الذي تعرفنا عليه 
من قبل عند التعرف على الخاصية .DataGridViewElement. State‏ 


معرفة أول صف :GetFirstRow‏ 
تعيد موضع أول صف له الحالة المرسلة كمعامل» وهي تستقبل إحدى قيم 
المرقم وع]7)5]2عدء1031301101/1611.. وتعيد هذه الوسيلة ١-‏ إذا لم 
تجد ضقا له الحالة المطلوبة. 
وتوجد صيغة أخرى لهذه الوسيلة لها معامل ثان هو أيضا من نوع المرقم 
125 وولكنه يستقل الحالة التي يجب ألا يكون 
عليها الصف.. والمثال التالي يعيد رقم أول صف معروض في جدول العرض 
لكنه غير محدد: 
MsgBox(DataGridView1.Rows.GetFirstRow(‏ 
DataGridViewElementStates. Displayed,‏ 
DataGridViewElementStates.Selected))‏ 


معرفة آخر صف :Ge)44۸8 0W‏ 
الحالة المرسلة كمعامل. 


معرفة الصف التالي :GetNextRow‏ 
تعيد رقم الصف الذي له حالة معينة» وهي تستقبل المعاملين التاليين: 
2< رقم الصف الذي سيبداً البحث منه. 
؟- إحدى قيم المرقم DataGrid ViewElementStates‏ توضح الحالة 
التي يجب أن يمتلكها الصف المطلوب. 
وتوجد صيغة ثانية لهذه الوسيلةء لها معامل ثالث» يستقبل قيمة من قيم المرقم 
95 تلوضح الحالة التي يجب ألا يمتلكها 
الصف المطلوب. 
والمثال التالي يعرض أرقام كل الصفوف المعروضة والتي لا يستطيع 
المستخدم تغيير حجمها: 
Dim Rows -< 1-775‏ 


°۹٩ 


Dim Pos = Rows.GetFirstRow( 
DataGridViewElementStates.Displayed, 
DataGridViewElementStates.Resizable) 

Do Until Pos = -1 

MsgBox(Pos) 

Pos = Rows.GetNextRow(Pos, 
DataGridViewElementStates.Displayed, 
DataGrid ViewElementStates.Resizable) 

Loop 


معرفة الصف السابق :GetPrevious Row‏ 
مماثلة للوسيلة السابقة في صيغتيهاء ولكنها تبحث في المجموعة من الخلف 
إلى الأماب بذعا من الموضع الذي أرسلته إلى المعامل الأول.. دعنا نكتب 
المثال السابق باستخدام هذه الوسيلة» لعرض أرقام الصفوف بترتيب عكسي: 
Dim Rows -< 1-775‏ 
Dim Pos = Rows.Count -1‏ 
Do‏ 
Pos = Rows.GetPreviousRow(Pos,‏ 
DataGridViewElementStates.Displayed,‏ 
DataGridViewElementStates.Resizable)‏ 
If Pos = -1 Then Exit Do‏ 
MsgBox(Pos)‏ 
Loop‏ 
لاحظ أننا بدأنا البحث من موضع يساوي عدد الصفوف» رغم أن ترقيم 
الصفوف يبدأ من الصفر وينتهي عند عدد الصفوف ..١-‏ السبب في هذا هو 
أن هناك صفا زائدا (هو الصف الجديد الذي تجاوره العلامة * في جدول 
العرض)» لهذا يمكن أن نأخذه في اعتبارنا.. أما لو حاولت أن تبدأ البحث من 
موضع يزيد على عدد الصفوف (مثل 1 + 0016©) فسيحدث خطأ في 
البرامج. 
معرفة عدد الصفوف :GetRowCount‏ 
تعيد عدد صفوف الجدول التي لها الحالة المرسلة كمعامل» وهي تستقبل إحدى 
قيم المرقم .DataGridViewElementStates‏ . والمثال التالي يعرض عدد 
0 المحددة في جدول العرض 
MsgBox(DataGridView1.Rows.GetRowCount(‏ 
DataGridViewElementStates.Selected))‏ 
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7# معرفة ارتفاع الصفوف :GetRows#Height‏ 
ترد مجموح ارقا ع الضفوف الى لها الكالة النربيلاة عامل » رهي تال 
إحدى قيم المرقم .DataGrid ViewElenentStates‏ 


#> صف مشترك 5121:60119018: 
تعيد كائن الصف :123301101716110 الذي يمثل الصف المشترك 
الموجود في الموضع المرسل كمعامل.. وسنتعرف على مفهوم الصفوف 
المشتركة 1001585 513160 بالتفصيل لاحقا. 


كما تمتلك هذه المجموعة الحدث التالي: 


:ColIlectionChanged المجموعة تغيرت‎ F 
ينطلق هذا الحدث عند حدوث تغير فى عناصر المجموعة بالحذف أو‎ 
الإضافة.. والنعامل الثاني ء لهذا الحدث من التوع‎ 
وقد تعرفنا عليه من قبل عند التعرف‎ 19 

على مجموعة الجداول .DataTab1leCo1lection‏ 


°۹۸ 


DataGrid View Row Class فئة صف جدول العرض‎ 4 


هذه الفئة ترث الفئة 0 103430110571611 وهي تمثل أحد صفوف جدول 
العرض.. وتمتلك هذه الفئة الخصائص التالية: 


"57 ف كائن سهولة الوصول :AccessibilityObject‏ 
تعيد كائن تسهيل الوصول ء٠‏ زطا0ء1ط1وومءء۸ المستخدم مع الصف الحالي 
افسهيل تعامل ذوي الاحتياجات الخاصة (كضعاف اليصر) مع بيانات بهذا 
الصف هذا الموضوح خارج تنطاق هذا الكناب: 


7 ف الخانات واامءC:‏ 
تعيد مجموع الخانات 15)اء1(313011017165061100116 التي تحتوي على 
خانات الصف الحالي.. والمثال التالي يعرض قيمة الخانة الأولى في الصف 
الأول» nea‏ أن صف ر ءوس الأعمدة وعمودرءوس الصفوف لا 
يدخلان في الترقيم 
MsgBox(DataGridView1.Rows(0).Cells(0). Value)‏ 
لكني أنصحك ألا تستخدم رقم العمود للإشارة إلى الخانة كما في المثال 
السابق» لأنك قد تغير موضع العمود بعد ذلك أو تضيف أعمدة أخرى قبله 
تؤدي إلى تغيير ترقيمه» مما يضع عليك عبء إعادة تغير كل الأكواد التي 
تحتوي على أرقام الأعمدة. 
أنصحك أيضا ألا تستخدم اسم العمود للإشارة إلى الخانة مثل: 
MsgBox(DataGridView1.Rows(0).Cells("C011'").Value)‏ 
فحتى لو لم تكن ستغير اسم العمود بعد هذاء فكتابة اسم نصي بهذه الطريقة قد 
إذن فما أنسب حل؟ 
أسهل حل لهذا الأمرء هو منح الأعمدة عند تعريفها في جدول العرض أسماء 
برمجية واضحة (مثل عصهN[ه٤)»‏ واستخدام الخاصية 100162 الخاصة 
كان اعود الحصبول على ركه الأشارة الى الخانة من خلاله مثل: 
MsgBox(DataGridView1.Rows(0).Cells(‏ 
ColName.Index).Value)‏ 
بهذه الطريقة لن يتأثر الكود بتغيير موضع العمود بعد ذلك» وفي نفس الوقت 
هذا الكود واضح وقابل للقراءة والفهم كما في حالة استخدام الاسم النصي 
للعمود» لكن بدون أي احتمال للخطأ في كتابة الاسم. 


7 فع العنصر المرتبط بالبيانات 22:وع1221421301120116: 


2 


تيد الان اذى برش السيف الماك اتةه لو أخنت المشروع 
BindGridToArray‏ دان إن هذه الخاصية تعيد م التلميد Student‏ 
و الزر DataBoundIten‏ في هذا e‏ فستظير لك رسالة 
تخبرك بتفاصيل كائن التلميذ المرتبط بهذا الصف. 

أما لو كان جدول العرض مرتبطا بجدول من مجموعة البيانات» فستعيد هذه 
الخاصية كائن عرض الصف 123431901857168 الذي يحوي بيانات الصف 
المعروض حاليا. 

لاحظ أن أي تغيير ستجريه على الكائن المرتبط بالصف الحالي سينتقل إلى 
مصدر البيانات» ومن ثم سيظهر هذا التغيير في جدول العرض مباشرة. 


أ الارتفاع Height‏ : 
تقرأ أو تغير ارتفاع الصف الحالي.. والقيمة الافتراضية لهذه الخاصية هي 
الارتفاع المناسب لخط الكتابة الحالي + ٩‏ نقاط و[عرزم 9. 


ا JÎ‏ ارتفاع :MinimumHeight‏ 
تقرأ أو تغير أقل ارتفاع يمكن أن يقبله الصف الحالي.. وأقل قيمة لهذه 
الخاصية هي ؟» والقيمة الافتراضية لها هي .٣‏ 


“5 ارتفاع الفاصل :Divider Height‏ 
تحدد حجم المساحة التي تفصل الصف الحالي عن الصف التالي.. هذا الفاصل 
ك ا مق الصيف ألقالي: إلا انبا لا توفي ا وظيفة مق وظطائفة ما عدا 
العمل كفاصل شكلي. . والصورة التالية توضح تأثير وضع القيمة ٠١‏ في هذه 
الخاصية في الصف الثاني: 





والقيمة الافتراضية لهذه الخاصية هي صفرء لهذا لا يوجد أي فاصل بين 
الصفوف» ما عدا خطوط الشبكة العادية. 











3 نص الخطأ :Error Text‏ 
تقر أى تغين النصن الذى يشرح الأخطاء التى حدت في العسرد: مثلما يدت 
عكديا يكنب المستكدى كينا كور سموح ا ی كاداك المعرة أو عندما 
توضع قيمة في الخاصية 111011 الخاصة بأحد صفوف مجموعة 

البيانات المرتبطة بجدول العرضء فهذا الخطأ ينتقل آليا إلى جدول العرض. 
وتظهر أيقونة حمراء في هامش الصف لتنبه المستخدم إلى وجود خطأء 
وعندما يحلق فوقها بالفأرة» سيظهر له تلميح يعرض النص الموجود في 


الخاصية )هرء 1[ 111101. 


ونج خانة رأس الصف :HeaderCel[]‏ 
تق رأ أو تغير كائن الخانة الرئيسية DataGridViewRowHeaderCe1|‏ 
التي تتحكم في خانة رأس الصف الحالي. 


57 زوز هل هو جديد WR 0W‏ YNe؟1:‏ 
تعيد 1:16 إذا كان الصف الحالي هو الصف الجديد الموجود في اخر صف 
في جدول العرض وتجاوره العلامة *.. هذا الصف موجود فعلا في مجموعة 
صفوف الجدول» لكنه يظل صفا جديدا إلى أن يكتب فيه المستخدم أية قيمةء 
حيث يصبح صفا عادياء ويضاف صف جديد بدلا منه. 


كنا متاك هذه الفقة الوسائل الكالية: 


#> ضبط طراز حافة رأس الصف :AdjustRowHeaderBorderStyle‏ 
تعدل شكل حافة رأس الصف الحالي عندما يبدأ المستخدم تحريره.. وتستقبل 
هذه الوسيلة المعاملات التالية: 

- كائن طراز الحافة المتطور DataGridViewAdvancedBorderStyle‏ 

- كائن طراز الحافة المتطور الذي سيستخدم لحفظ التغييرات البينية التي 
تحدث لرأس الصف. 

- معامل منطقي» إذا جعلت قيمته 1516 ستتم إضافة حافة رأسية مفردة 
إلى رأس الصف. 

- معامل منطقي» إذا جعلت قيمته 1506 ستتم إضافة حافة أفقية مفردة إلى 
رأس الصف 

- معامل منطقي» أرسل إليه 10 إذا كان الصف الحالي هو أول صف 
معروض في الجدول. 


ب 


- معامل منطقي» أرسل إليه 1516 إذا كان الصف الحالي هو آخر صف 
معروض في الجدول. 

OE. BETE E r وليه‎ 

GridView Advanced BorderStyle‏ t4ط‏ الذي يمثل طراز الحافة المعدل. 

لاحظ أنك لست مضطرا إلى استخدام هذه الوسيلة يدوياء فجدول العرض 

دند ها كلقافيا لخ شكل وات الغانات إلر تة الصف ف عند قد يز ها. 


إنشاء خانات :CreateCells‏ 
تحذف جميع خانات الصف الحالي» وتنشئ بدلا منها خانات جديدة» كل خانة 
منها مستمدة من قالب الخانة عاهامم ٥٠11٣‏ الخاص بالعمود الذي توجد 
به.. ولهذه الوسيلة صيغتان: 
-١‏ الصيغة الأولى تستقبل كائن جدول العرض 10312011017167 الذي 
سيتم استخدام قوالب الخانات الخاصة بأعمدته. 
TERE‏ الثانية نزو على EE‏ المنايقة ET‏ نسل 
مصفوفة كائنات «Object Array‏ بها القيم التي ستوضع في الخانات 
الجديدة. 


0# معرفة رف القائمة الموضعية :GetContextMenuStrip‏ 


تعيد كائن رف القائمة الموضعية ContextMenuS 1p‏ الخاص بالصف 
الذي ترسل رقمه إليها كمعامل. 


> معرفة نص الخطأ :GetError Text‏ 


تعيد نص الخطأ الخاص بالصف الذي أرسلت رقمه كمعامل. 


#ا> معرفة الارتفاع المفضل :GetPreferred Height‏ 


تعيد أنسب ارتفاع للصف» وهي تستقبل المعاملات التالية: 
- رقم الصف المراد حساب أنسب ارتفاع له. 
- إحدى قيم المرقم ataGridViewAutoSizeRowModeطD‏ التي 
توضح كيف سيتم تغيير حجم الصف تلقائياء وهذه القيم هي: 
AllCells‏ يتم تغيير ارتفاع الصف ليناسب محتويات 
جميع خاناته» بما فيها الخانة الرئيسية. 
AllCells‏ يتم تغيير ارتفاع الصف ليناسب محتويات 
ExceptHeader‏ | جميع خاناته» ما عدا الخانة الرئيسية. 
إيتم تغيير ارتفاع الصف ليناسب محتويات 











1۲ 

















الخانة الرئيسية 1ع11620]. 


- معامل منطقي» إذا جعلت قيمته عن[ » فسيتم تقدير الحجم المناسب 
على اعتبار أن عرض الصف سيظل ثابتا.. أما إذا جعلته 10156 
فسيؤخذ فى الاعتبار أن الأعمدة التى توجد فيها خانات الصف قد تغير 
حجمها تلقائيا لمراعاة التغير الذي حدث في ارتفاع الخانات. 





2# معرفة الحالة ©02)]5)26©: 
توضح حالة الصف الذي أرسلت إليها رقمه كمعامل» وهي تعيد إحدى قيم 
المرقم sعViewElementStat hata Gri‏ الذي تعرفنا عليه من قبل. 


ملحوظة: 
كل من الو س ائل «GetErrorText ‘GetContextMenuStrip‏ 
GetState ›GetPreferred Height‏ تبدو عجيبة للغاية» فمعاملها يرشحها 
بجدارة لأن تكون وسيلة مشتركة 51360 لأنها لا تتعلق بالصف الحالي 
تحديداء وإنما تتعامل مع أي صف ترسل إليها رقمه. ولكن رغم هذا فهي 
ليست وسيلة مشتركة» فيا ترى ما هو السبب؟ 
في الحقيقةء هذه الوسائل مصممه 3 للتعامل مع الصف الحاليء لهذا عليك أن 
ترسل إليها تحديدا رقم الصف الحالي دون غيره.. والكود التالي سيسبب 
خطأ في البرنامج بسبب إرسال الرقم صفر (رقم أول صف) إلى الوسيلة 
State‏ الخاصة بالصف رقم ۲ (الصف الثالث): 
MsgBox(DataGridView1.Rows(2).GetState(0).ToString)‏ 
بينما لو جربت الكود التالي فلن تحدث مشكلة! 
MsgBox(DataGridView1.Rows(0).GetState(0). ToStrin)‏ 
فيا ترى لماذا تم إنشاء هذه الوسائل بهذا الشكل العجيب؟ 
السبب في هذا هو أن الخاصية × لم[. hata Gri View R 0w‏ التي تحمل 
رقم الصف تعيد ١-‏ إذا كان الصف مشتركا «Shared Row‏ وفي مثل هذه 
الحالة تناط بك مهمة إرسال رقم الصف الفعلي إلى هذه الوسائل!.. وطبعا 
عليك ألا تستخدم الخاصية عجع110 لأنها لو أعادت ١‏ وأرسلته إلى هذه 
الوسائل فسيحدث خطأ في البرنامج! 
لو شئت رأيي الشخصيء فتقنية مشاركة الصفوف - التي سنتعرف عليها 
بالتفصيل لاحقا ‏ تسبب بعض التعقيد في الأمورء رغم أنها توفر الكثير من 
مساحة الذاكرة في التطبيقات الكبيرة. 








7# وضع القيم ومںu‏ او ۷٤مS:‏ 




















أرسل إلى هذه الوسيلة مصفوفة كائنات :1123 4ن ه[0 لوضع القيم التي 
تحتويها في خانات الصف الحالي.. وتعيد هذه الوسيلة 1:16 إذا نجح وضع 
جميع القيم في جميع الخانات؛ أما إذا فشل وضع بعض القيم فستعيد 118196.. 
وإذا كانت المصفوفة تحتوى على عناصر أكثر من عدد خانات الصف» فإن 
القيم الزائدة يتم إهمالها وتوضع باقي القيم في خانات الصف» ولكن هذه 
الوسيلة تعيد 752156.. أما إذا كانت المصفوفة تحتوي على عناصر أقل من 
خانات الصف» فسيتم ملء بعض الخانات بالقيم الموجودة» وستترك باقي 
الخانات كما هي بدون تغيير. 
لابفظ أن ليك إرسال تضفر فة قاقات تتحذوداء لأنك لى ار لت مو فة قيمية 
ype Array‏ ا-ueاVa‏ (مثل مصفوفة من الأعداد الصحيحة) إلى هذه 
الوسيلة كمعامل» فإنها ستعتبرها قيمة واحدة وتضعها كلها في أول خانة في 
الصف!.. ولحل هذه المشكلة أمامك طريقتان: 
- فإما أن تحول المصفوفة القيمية إلى مصفوفة كائنات» بطريقة مثل: 
Dim Arr( ) As Integer = {1, 2, 3, 4}‏ 
Dim O(4Arr.Length - 1) As Object‏ 
Arr.CopyTo(O, 0)‏ 
Row.SetValues(O)‏ 
- وإما أن ترسل القيم كمجموعة من المعاملات المفردة إلى هذه الوسيلة 
بدون وضعها في مصفوفة» وستقوم هي بجمعها في مصفوفة كائنات» 
مثل: 
Row.SetValues(1, 2, 3, 4)‏ 


4 فئة خانة جدول العرض DataGrid ViewCell Class‏ 


هذه الففة ترث الفئة rid View 81em‏ ta6GهD»‏ وهي فئة أساسية مجردة 
Abstract Base 595‏ تشتق منها كل أنواع خانات جدول العرض. 

والمتلبك هيذن و خضب انض ا کک ا کا ا ف 
4 وكائن العمود DataGrid ViewColumn‏ وكائن 
الصف :123130110171611101: لهذا لن نكرر شرحها هناء وهي: 


“57 فل مثبتة جرء1”02 57 فز معروضة 115719760 

وحم للقراءة فقط ReadOnly‏ 57 فز قابلة لتغيير الحجم م[طهرزوءR‏ 
أ محددة Selected‏ "57 فر مرئية م[طذئز۷ 

و نوع القيمة Value Type‏ 3 الوسم ع1'2' 

ا نص تلميح الأداة )10017131 57 نص الخطأ مره 1001 

وخ الطراز 5616 ف لها طراز 11255616 


ف الطراز الموروث InheritedStyle‏ 
57 ف كائن تسهيل الوصول )ع [1111001ووء©0 م 
وخ رف القائمة الموضعية Context MenuStrip‏ 


وإضافة إلى هذه الخصائص» تمتلك هذه الفئة الخصائص التالية: 


57 هزر رقم العمود :ColumnIndex‏ 
تعيد رقم العمود الذي توجد فيه الخانة الحالية. 


57 ف العمود المالك :OwningColumn‏ 
تعيد كائن العمود 103120011017165000[1:1 الذي توجد فيه الخانة الحالية. 


57 فط رقم الصف :RowIndex‏ 
تود ركم الصف الذي توح فيه الخافة التحالية 


57 فز الصف المالك :OwningRow‏ 
تعيد كائن الصف 1(213001101/1611207 الذي توجد فيه الخانة الحالية. 


57 فز الحجم مSiz:‏ 
تعيد كائن الحجم ع517» الذي يحمل أبعاد الخانة الحالية. 


“o 


7 فع الحجم المفصل :PreferredSize‏ 
تعيد كائن الحجم م812» الذي يحمل أنسب أبعاد للخانة الحالية لكي تستوعب 
5 ياتها | 5 ابا كاملا 


57 فط حدود المحتوى :ContentBounds‏ 
تعيد كائن المستطيل عاع ممع 1: الذي يحمل موضع ومساحة محتويات 
الخانة الحالية. . تذكر أن الخانة قد تحتوي على نص أو صورة أو مربع اختيار 
أو زر أو أية أداة أخرىء لهذا فإن هذه الخاصية تعيد إليك حدود الأداة 
المحتواة في الخانة. 

57 فط حدود أيقونة الخطأ :ErrorlIconBounds‏ 
تعيد كائن المستطيل ءاعمه)ءء۸› الذي يحمل موضع ومساحة أيقونة الخطأ 
التي تعرضها الخانة الحالية (إن وجدت). 

7 فط القيمة الافتراضية للصف الجديد :DefaultNew Row Value‏ 
تعيد كائنا 1ع 0[6» يحتوي على القيمة الافتراضية للخانة الحالية إذا كانت في 
الصف الجديد (اخر صف في جدول العرض). 
وتفيدك هذه الخاصية عنما تنش تر عا خاصا يك من الخائات فى هذه الحالة 
غلك أن تخل هذه الخاضية تعد القيفة الاق اضنية للكانة الحديدة : مكلا لو 
كنت تتعامل مع خانة تستقبل أيقوناتء يمكنك أن رض فالات الد 
أيقونة في شكل علامة استفهام.. وإن كنت تتعامل مع خانة تاريخ: فيمكنك أن 
تضع في الخانة الجديد التاريخ اليوم الحالي.. وهكذا. 


5 القيمة 106ج7؟: 
تقرا أو تغير قيمة الخانة الحالية» وهي من النوع †ءءزطا0.. مثال: 
DataGridView1.Rows(0).Cells(0).Value = "Test"‏ 


57 ف القيمة المنسقة :Formatted Value‏ 
تعيد كائنا ٥زط0‏ يحمل القيمة المنسقة للخانة الحالية.. لاحظ أن القيمة 
الموحودة فى الحائة قد تكون نضا مق سخا بے تنسيق هذا النص كاري 

"557 فز نوع القيمة المنسقة :Formatted Value Type‏ 
تعيد كائق رعو الذى يمال نوع القيمة المنية” المويجرية في ا 


1 


57 فيز القيمة المعدلة المنسقة :Edited Formatted Value‏ 
كيف ا الحالدة ا بالشوق المطلوي» کے لر كافك الاد ف رت 
التحرير وكتب بها المستخدم قيمة لم تقبل بعد.. وبهذا تختلف عن الخاصية 
ueا۴0rmattedVa»‏ التي تعيد القيمة المحفوظة في الخانة فعلا. 


ملحوظة: 

إذا استخدمت الحدث ع1)01121مع1م061100) الخاص بجدول العرض» 
لفحخصص قيمة خاانة في عمدود م نالتنوع 
مع 7 فاس ب تخدم الخاص ية 
Edited Formatted Value‏ لقراءة قيمة الخانة؛ ولا تستخدم الخاصية 
116/. السبب في هذا أن الخانة الموجودة في عمود مربعات الاختيارء لا 
تغير قيمتها إلى القيمة الجديدة إلا بعد مغادرة المؤشر 700115 للصف الذي 
توجد فيه!! 








ف نوع التحرير عم1701617: 

تعيد كائن النوع عم:158؛ الذي يمثل الأداة التي توضع في الخانة عند 
تحريرها.. مثلا: عند تحرير أي خانة في عمود نصي» يوضع فيها مربع نص 
من gill‏ ع DataGridView extBoxEditing Control]‏ لاستقبال ما يكتبه 
من gill‏ ع .DataGridViewComboBoxEditingContro1‏ 

وقد استبدلنا م لم0 هذه الخاصية في الفئة 0231620231)00611 في المشروع 
DataGridColumnTypes‏ لجعلها تعيس د اانوع 
18202:01 هه وهو نوع أداة تحرير خاصة بناء أنشأناها 
للتعامل مع الخانات التي تعرض أداة اختيار التاريخ .<DateTime Picker‏ 


7 ف هل هو في وضع التحرير ©151111001031006: 
تعيد م1۲ إذا كانت الخانة في وضع التحرير حاليا. 


"57 فر الحالة الموروثة :InheritedState‏ 
تعيد إحدى قيم المرقم وع1231201101/16111:1»21©0451214 التي توضح حالة 
الخانة الحالية. 


كما تملك هذه الفقة الوسائل الثالية: 











5 # قياس ارتفاع النص :MeasureTextH eight‏ 
تحسب الارتفاع اللازم لرسم النص المرسل إليها.. هذا مفيد لمعرفة أنسب 
اء لاحت ,ايه هذا ال قل رخ ا خا رل هذه لرا 
المعاملات التالية: 

كائن الرسوم 1105م13) المستخدم في رسم النص. 

النص المراد قياس عرضه. 

كائن الخط 104 الذي سيكتب النص به. 

أقصى عرض يمكن رسم النص فيه (عرض العمود). 

إحدى قيم المرقم و121'011211'128' توضح تنسيق النص» وهي: 


Default 
Bottom 
Top 
Left 
Right 
RightToLeft 
HorizontalCenter 
VerticalCenter 
EndEllipsis 


PathEllipsis 
ExpandTabs 
ExternalLeading 


HidePrefix 
Internal 
ModifyString 
NoClipping 


GlyphOverhang 
Padding 
NoPadding 
LeftAndRight 
Padding 
NoPrefix 








التنسيق الافتراضي. 

محاذاة النص إلى أسفل. 

محاذاة النص إلى أعلى. 

محاذاة النص إلى اليسار. 

محاذاة النص إلى اليمين. 

رسم النص من اليمين إلى اليسار. 

توسيط النص أفقيا. 

توسيط النص رأسيا. 

رسم نهايات الخطوط الحادة بحواف 
مستديرة. 

رسم المسارات الحادة بحواف مستديرة. 
توسيع حروف الجدولة. 

إضافة عرض المسافة البادئة للخط إلى 
ارتفاع النص. 

إخفاء البادئة. 

استخدام خط النظام في عملية القياس. 

ليس لها تأثير. 

عدم قص علامات التشكيل الفوقية والسفلية 
التي تتجاوز مستطيل الرسم. 

إضافة هامش إلى مستطيل الرسم 
لاستيعاب علامات التشكيل الزائدة. 
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التذكيرية Mnemonic Characters‏ 
واعتباره حرفا عاديا. 

عدم استخدام الكشيدة لمط الحروف لجعل 
النص يشغل عرض المستطيل بالكامل. 
تستخدم مع ويندوز ۲۰۰۰ و 22. 

رسم النص في سطر واحد. 

تنسيق النص لعرضه في مربع نص. 

تقسيم النص إلى سطور في نهاية الكلمات. 
حذف اكات الزائدة عن غرطن السنطرء 
ووضع نقاط تكملة (...) بعد آخر كلمة 
ظاهرة. 

انتكداء التقطيع الخاضن يكائن الرسوم, 


E O E 
(كالتكبير والتصغير) الخاص بكائن الرسوم.‎ 





ويمكنك دمج أكثر من قيمة من هذه القيم باستخدام المعامل ا0. 


وتوجد صيغة أخرى لهذه الوسيلةء تزيد بمعامل سادس على الصيغة السابقةء 
وهو معامل منطقي مرجعي 1831161 يعمل كمعامل إخراج اام اا0»؛ وهو 
يعيد ع1:1' إذا كان عرض النص المرسوم أكبر من أقصى عرض مسموح به 


في المعامل الرابع. 


5 2# قياس عرض النص :Measure Text(Width‏ 
تسب العرطن اللازع ارمس الحصن الموسل إليهاء ولها المعاائلات الثالية: 
- كائن الرسوم و110م71223) المستخدم في رسم النص. 
- كائن الخط ٤٥و٥۴‏ الذي سيكتب النص به. 
- أقصى ارتفاع يمكن رسم النص فيه. 
- إحدى قيم المرقم وع1677*0150214112 التي توضح تنسيق النص. 
































© # قياس حجم النص :Measure1ex(Size‏ 
تعيد كائن حجم 5126 يحمل العرض والارتفاع اللازمين لرسم النص المرسل 
إليهاء وهي تستقبل المعاملات التالية: 

- كائن الرسوم كعاطمهإ6 المستخدم في رسم النص. 


كائن الخط "ه۴ الذي سيكتب النص به. 


إحدى قيم المرقم sعها1 ٠×۴ ٥۲٣2۲۴‏ التي توضح تنسيق النص. 


5 قياس الحجم المفضل للنص :Measure TextPreferredSize‏ 
عيد كان حجم و8512 يحيل الكدل e hS Ca‏ 
ل ا 


كائن الرسوم 105طم0123 المستخدم في رسم النص. 

النص المراد قياس عرضه. 

كائن الخط 10 الذي سيكتب النص به. 

عدد مفرد ع[ع5810 أكبر من صفر وأقل من ١ء‏ يحمل أقصى نسبة 
مسموح بها بين عرض وارتفاع النص عند رسمه. 

إحدى قيم المرقم وع1671"01202141'12 التي توضح تنسيق النص. 


ب ضبط شكل حافة الخانة :AdjustCelIBorderStyle‏ 

ممائلة للوسيلة «DataGridViewRow.AdjustRowHeaderBorderStyle‏ 
وها نفس المعاملاته و لكنها تقوم يضيط فكل حواف الخانة الحالية عندها 
تكون في وضع التحرير. 
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٠ 
هير‎ 9 


:InitializeEditing Control أداة التحرير‎ 


يقوم جدول العرض باستدعاء هذه الوسيلة مرة واحدة لإضافة أداة التحرير 
الخاصة بالخانة الحالية إلى أدوات التحرير التي يستخدمها.. وتستقبل هذه 
الوسيلة المعاملات التالية: 


ATONE 

كائن يحتوي على القيمة المنسقة 1١721116‏ 4م۲2٠۴‏ التي ستوضع 
مبدئيا في أداة التحرير عندما تظهر في الخانة. 

كائن طراز الخانة 103301101716170061156716 الذي يحتوي على 
الخصائص الشكلية للخانة» لاستخدامه في جعل أداة التحرير شبيهة 
بالخانة. 
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وقد استبدلنا ع230رع01) هذه الوسيلة في كود الفئة 021660123100611 في 
المشروع 65م:1021201100011525157 لجعل أداة اختيار التاريخ تعرض 
نفس التاريخ الموجود في الخانة عند ظهورها لآأول مرة. 


37 تحديد موضع أداة التحرير :PositionEditing Control]‏ 
تحدد موضع وأبعاد أداة التحرير في جدول العرضء ولها المعاملات التالية: 


معامل منطقي ۰8001٥4۸‏ إذا جعلت قيمته 116' فستوضع الأداة في 
الموضع الذي تحدده باقي المعاملاتء إما إذا جعلتها 72156 فسيترك 
للأداة تحديد موضعها بنفسها. 

معامل منطقي Boolean‏ اذا جعلت قيمته True‏ فسيتم تحديد حجم 
الأداة تبعا لباقي المعاملات» إما إذا جعلتها 18156 فسيترك للأداة تحديد 
كائن مستطيل ه1ع16013 يحمل موضع وأبعاد أداة التحرير. 

كائن مستطيل عاعة]1060 يحمل موضع وأبعاد المساحة التي يجب 
ألا تتجاوزها أداة التحرير. 

كائن »(ataG ri4 View € e118 †y1e‏ يحمل طراز الخانة. 

معامل منطقي» إذا جعلت قيمته ٥ں‏ إ1 فستضاف حافة رأسية مفردة 


إلى رأس الصف. 
معامل منطقيء إذا جعلت قيمته م٣1‏ فستضاف حافة أفقية مفردة إلى 
رأس الصف. 


معامل منطقىء أرسل إليه 116 إذا كانت الخانة موجودة فى أول 
عمود يعرضه الجدول. ۰ 
معامل منطقي» أرسل إليه 106 إذا كان كانت الخانة موجودة في أول 
صف يعرضه الجدول. ٠‏ 


7# تحديد موضع لوحة التحرير :PositionEditingPanel]‏ 
مشابهة للوسيلة السابقة» إلا أنها تحدد موضع اللوحة التي توضع عليها أداة 
التهريق.ذاخكل القانة ..وليذه الؤسيلة نفس معاملات الوسيلة السابقة ما هذا 
أول معاملين فهما غير موجودين هنا.. كما أن هذه الوسيلة تعيد كائن 
المستطيل عاعمج]ع26 الذي يحدد موضع وأبعاد أداة التحرير داخل لوحة 
التحرير. 
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ف 





إبعاد أداة التحرير :DetachEditingContro]‏ 
تزيل أداة الكتابة من الخانة الحالية» وتنهي وضع التحرير. 


معرفة الحالة الموروثة :GetInheritedState‏ 

تعيد إحدى قيم المرقم وعغ7]5120عدطع1 10313011017161 التي توضح 
الحالة الموروثة من جدول العرض أو العمود أو الصف الذي توجد به الخانة 
الحالية.. وتستقبل هذه الوسيلة كمعامل رقم الصف الذي توجد به الخانة. 


ملحوظة: 

لا تستطيع استخدام الخاصية 11611660516216 مع خانة موجودة في صف 
مشترك 1201 510 لأن الخاصية :1006 التي تشير إلى موضع هذا 
الصف تعيد القيمة »١-‏ لهذا يمكنك استخدام الوسيلة GetInheritedState‏ 
بدلا منهاء على أن ترسل إلبها رقم الصف الفعلي بنفسك. . لاحظ أن هذا هو 





الحال نفسه في كل الوسائل التالية التي تستقبل رقم الصف الذي توجد به 
الخانة كمعامل» في مكفيضية الك مل مع الكانات المرجوةة فى صقف 
ا 


معرفة حدود المحتوى :GetContentBounds‏ 
تعيد كائن المستطيل ع1ع1060122» الذي يمثل موضع وأبعاد محتويات الخانة 
الحالية.. ويجب أن ترسل إلى هذه الوسيلة رقم الصف الذي توجد به الخانة. 


معرفة القيمة المعدلة المنسقة :GetEdited Formatted Value‏ 
تين الق المكتوية الا فى الخادة حكن :ولو كادت فى رکم التدوين ری 
تستقبل المعاملين التاليين: 
.رقم المبكةالاى تر قالغا 
- قيمة من قيم المرقم DataGrid ViewDataErrorContexts‏ توضح 
محتوى الخطأ الخاص بالخانة» وهذه القيم هي: 


۴rmatting‏ | خطأ في تنسيق قيمة الخانة. 
1م2015 إخطأ في عرض القيمة من مصدر البيانات. 
6 | خطأ في حساب أفضل حجم للخانة.. فشلت 
الخانة في تنسيق محتوياتها. 
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0 | خطأ في حذف أحد الصفوف.. يحدث هذا إذا 
كان الصف مرتبطا بمصدر بيانات» وأطلق 
مصدر البيانات خطأ عند محاولة حذف هذا 
الصف منه. 

Parsing‏ خطأ في تحويل البيانات التي كتبها المستخدم أو 
0mm‏ | خطأ في حفظ بيانات الخانة في مصدر 
البيانات. 
711 أخطأ في استعادة القيمة الأصلية للخانة عند 
Restoration‏ | محاولة إلغاء التحرير الحالي»ء وذلك بسبب 
تغير تنسيق الخانة. 
6376001101 | خطأ عند مغادرة جدول العرضء بسبب عدم 
11 | خطأ عند محاولة مغادرة الخانة الحالية» بسبب 
Change‏ وجود أخطاء فيها. 
Scroll‏ خطأ في الانزلاق» بسبب ظهور خانة بها 
0 خطأ عند نسخ محتويات الخانة إلى لوحة 
Content‏ القصاصات ل02۲ طم11اC»‏ بسبب عدم إمكانية 
تحويل محتويات هذه الخانة إلى نص. 
































لاحظ أنك تستطيع دمج أكثر من قيمة من قيم هذا المرقم معا باستخدام 


المعامل :01. 
5# معرف ورف القانعلة الموض ية الوروث 


:GetInheritedContextMenuStrip 
الموروث من‎ ContextMenuS†r1p تعيد كائن رف القائمة الموضعية‎ 
جدول العرض أو العمود أو الصف الذي توجد به الخانة الحالية.. وتستقبل‎ 

هذه الوسيلة كمعامل رقم الصف الذي توجد به الخانة. 


© معرفة الطراز الموروث 16ج)051ع)11ءطه])ء ©: 
تعيد كائن طراز الخانة 115671ع1021201101/1610 الموروث من الجدول 
أو العمود الذي توجد به الخانة.. وتستقبل هذه الوسيلة المعاملات التالية: 
- كائن طراز الخانة 10330011017161061156716 الذي ستوضع 
فاك ال ار الروت فة 
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- رقم الصف الذي توجد فيه الخانة. 
- معامل منطقي إذا جعلته 116 فستضاف خصائص الألوان ضمن 
الطراز الموروث. 


17> هل يبدأ الزر وضع التحرير :KeyEnters EditMode‏ 

تعيد 116 إذا كان ضغط الحرف المرسل إليها كمعامل يبدأ تحرير الخانة 
الحالية» علما بأن معامل هذه الوسيلة من نوع الفئة وع41.)مء557/(ع12» وهي 
نوع المعامل ع في حدث ضغط الزر ووع9722ع12.. والمثال التالي يخبرك إن 
كان ضغط حرف الإلغاء »م275 يبدأ عملية التحرير أم لا (بافتراض أن 

611" هو متغير يشير إلى خانة من خانات الجدول): 
Dim K As New KeyEventArgs(Keys.Escape)‏ 
MsgBox(Cell.KeyEntersEditMode(K)) ' Fales‏ 


# تحويل القيمة المنسقة :ParseFormatted Value‏ 
تحول القيمة المنسقة المعروضة فى الخانة إلى القيمة الأصلية» وهى تستقبل 
المعاملات التالية: 1 ١‏ 
- كائن +ع [06) يحمل القيمة المنسقة. 
- كائن طراز الخانة .DataGridViewCe11Style‏ 
- كائن من النوع "محول القيمة" 15006002561161 لاستخدامه لتحويل 
القيمة المنسقة.. ويمكنك إرسال القيمة عزطغ710 لاستخدام المحول 
الافتراضي. 
- كائن من النوع "محول القيمة" :19/060050 لاستخدامه للتحويل 
إلى القيمة الآصلية للخانة.. ويمكنك إرسال القيمة 710108 لاستخدام 
المحول الافتراضي. 
لاحظ أن جدول العرض يستدعي هذه الوسيلة تلقائيا بعد إدخال المستخدم لقيمة 
جديدة في أي خانة» لهذا لست مضطرا إلى استدعائها بنفسك. 
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5# فئة خانة مريع النص 
DataGrid ViewTextBoxCell Class‏ 


هذه الفئة ترث الفئة 1[ع ٣‏ wء1‏ 026۲11۷ وهي تعمل كخانة في جدول العرض 
تعرض نصاء وعند تحريرها تعرض مربع نص لاستقبال نص جديد من المستخدم. 
وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخاصية التالية: 


وخ أقصى طول للمدخلات :MaxInputLength‏ 
تحدد أقصى عدد من الحروف تقبله الخانة الحالية. 


وفي المشروع وءم/15 صدطدا103120611000[1» أنشأنا الفئة 11 02162012100: وهي 
ترث الفئة e×8 0×٣ e11‏ 1 173130011017167 لتكون قابلة للتحريرء ولكننا استبدلنا 
بعض خصائصها لتسمح بعرض أداة اختيار التاريخ Date 1ine P¡ck) e۲‏ بدلا من 
مربع النص.. ولو فحصت كود هذه الفئة» فستلاحظ أنه بسيط للغاية» فهو يدور 
حول نوع أداة التحرير المستخدمة في الخانة» ونوع القيمة التي تتعامل معها. 


## ففة خانة الزن 
DataGrid View ButtonCell Class‏ 


هذه الفئة ترث الفئة ٣11‏ سع 06۲14۷1 وهي خانة تعرض زرا. 
وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخاصيتين التاليتين: 
77 طريقة العرض المسطح 16:و)1125: 

:UseColumnTextForButton Value استخدام نص العمود كقيمة للزر‎ E 
لكنهما تؤثران فقط على الخانة الحاليةء‎ DataGrid ViewButton Column 
ولف على كل غت امود‎ 


E 


59 واجهة خننة التحرير 
IDataGridViewEditingCell Interface‏ 


تقدم هذه الواجهة إلى خانات جدول العرض التي تمثلهاء القدرة على تحرير 
النستخد مها ر تلك كذه الواحهة الغتاصير القالية. 


وخ هل تغيرت قيمة خانة التحرير :EditingCelIValueChanged‏ 
اجعل قيمة هذه الخاصية م11 » إذا تغيرت قيمة الخانة في وضع التحرير. 


و- القيمة المنسقة لخانة التحرير :EditingCelIFor matted Value‏ 
تقرأ أو تغير القيمة المنسقة التي تحتويها الخانة في وضع التحرير. 


2# معرفة القيمة المنسقة لخانة التحرير :GetEditingCelIFormatted Value‏ 
تعيد كائنا ٤مم‏ زا0 يحتوي على القيمة المنسقة لخانة التحرير.. وتستقبل هذه 
الوسيلة إحدى قيم المرقم DataGridViewDataErrorContexts‏ التي 
توضح نوع الخطأ الذي حدث بالخانة» وقد تعرفنا عليه من قبل. 


3 تجهيز خانة التحرير للتحرير :PrepareEditingCelIFor Edit‏ 
ت ز الخانة عند بدء وضع التحريرء وهي تستقبل معاملا نطقياء إذا جعار” 
قيمته م1۲ فسيتم تحديد النص المكتوب في الخانة. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 
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24 فئة خانة مربع الاختيار 
DataGrid ViewCheckBoxCell Class‏ 


هذه الففة ترث الفئة ¡4V ¡ew٣ e11‏ 6هtهD»‏ كما أنها تمثل الواجهة 
Grid ViewEditingCel|‏ و وهي تعمل كخانة في جدول العرض تعرض 
مربع اختيار .CheckBox‏ 
ولحدث إنشاء هذه الفئة صيعتان: 

-١‏ الصيغة الأولى بدون معاملات. 

؟- والصيغة الثانية تستقبل معاملا منطقيا ه80016» يتم إرسال قيمته إلى 

.ThreeState الخاصية‎ 

وإضافة إلى ما ترثه من الفئة الأم» وما تمثله من عناصر الواجهة 
[DataGrid ViewEditingCel1‏ تمتلك هذه الفئة بعض الخصائص الشبيهة 
بخصائص الفئنة ›DataG rid ViewCheckBoxCol um‏ وهي تقوم بنفس 
الوظيفة لكنها تتعامل مع الخانة الحالية فقط وليس العمود كله»ء لهذا لن نكرر شرحها 
هناء وسنكتفي بذكر أسمائها: 
وخ طريقة العرض المسطح ع71ج1”13651 
3 ثلاثي الحالة ThreeState‏ 
7 القيمة الخاطنة 173156572111 
القيمة الصحيحة TrueValue‏ 
وخا القيمة غير المحددة Indeterminate Value‏ 
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8 فة خانة الصو, 
DataGrid ViewImageCell Class‏ 


هذه الفئة ترث الفئة V1 عw ٣11‏ ۲14 6)ة(؛ وهي تعمل كخانة في جدول العرض 
تعرض صورة أو أيقونة. 
ولحدث إنشاء هذه الفئة صيعتان: 
-١‏ الصيغة الأولى بدون معاملات. 
؟- والصيغة الثانية تستقبل معاملا منطقيا ه80016» يتم إرسال قيمته إلى 
الخاصية .ValuesAre1Icons‏ 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة بعض الخصائص الشبيهة 
بخصائص الفئة 860001111 13آ1(31201101/161» وهي تقوم بنفس الوظيفة 
ك ا الا الحالي! فكو ليون الود كلف لهذا دن رر كوخا ها 
وسنكتفي بذكر أسمائها: 

Description الوصف‎ 3 

3 مخطط الصورة 112212561270116 

ھل القيمة أيقونة «م 772106151 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 
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8 فنة خانة الوصلة 
DataGrid ViewLinkCell Class‏ 


هذه الففة ترث الفئة 11م V1 ew٣‏ 14ا »Data6‏ وهي تعمل كخانة في جدول 
العرض» بها وصلة ع1م1.آ. 

وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة بعض الخصائص الشبيهة 
بخصائص الفئة 001111)>لطا.آ1(0312011017161» وهي تقوم بنفس الوظيفة 
لكنها تتعامل مع الخانة الحالية فقط وليس العمود كله؛ لهذا لن نكرر شرحها هناء 
وسنكتفي بذكر أسمائها: 


3 استخدم نص العمود كقيمة للوصلة UseColumnTextForLinkValue‏ 
]ا سلوك الرابط LinkBehavior‏ 
لون الرابط LinkColor‏ 
لون الرابط الفعال ActiveLinkColor‏ 
لون الرابط المُزار 010 7715106011510 
'] تتبع حالة الزيارة TrackVisitedState‏ 


كما تمتلك: هذه الفنة الخاضية الثالية: 


أ تمت زيارة الرابط 1660و1.101571: 
إذا جعلت قيمة هذه الخاصية 1516» فإن الرابط يأخذ اللون المحدد في 
الخاصية 771516011100101.. لاحظ أن لون الرابط يتغير تلقائيا عندما 
يضغطه المستخدم إذا كانت للخاصية ع11/151605126ع123 القيمة True‏ . 
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3# فئة خانة القائمة المركبة 
DataGrid ViewComboBoxCell Class‏ 


هذه الفئة ترث الفئة 1[ع ٣‏ wء1‏ 026۲11۷ وهي تعمل كخانة في جدول العرض 
بها قامة مركبة ×>0b080ص€0.‏ . 
وإضافة إلن ما تركه من ال الأ تمك هته الفا بسكن القصاتضن الشبيية 
بخصائص الفئة »DataG ri View CombokB0x>Co[ u1‏ وهي تقوم بنفس 
الوظيفة لكنها تتعامل مع الخانة الحالية فقط وليس العمود كلهء لهذا لن نكرر شرحها 
هناء وسنكتفي بذكر أسمائها: 
و2 تكملة تلقائية AutoComplete‏ 
3 مصدر البيانات DataSource‏ 
وخا عنصر العرض Display Member‏ 

أ عنصر القيمة ValueMember‏ 
وخ مرتبة 501160 
57 ف العناصر وبررء16 
طریقة العرض المسطح 10136516 
و طريقة العرض »12150123516981 
و طريقة عرض الخانة الحالية فقط DisplayStyleForCurrentCe11O0 nly‏ 
يونعم أقصى عدد من العناصر المسدلة MaxDropDownItems‏ 
3 عرض القائمة المنسدلة DropDown Width‏ 


ربط مصدر بيانات خانة بمصدر بيانات خانة أخرى: 

يمكنك تغيير مصدر بيانات خانة فى أحد الأعمدة» تبعا لقيمة خانة أخرى فى عمود 
آخر فى تفس الضف.. مثال: إذا كان هناك عمود تعرطن خاناته أسماء المحافظات: 
وبحوارة كرد تر كن كاه اء المدس مكف حمل كانة أسماء السدن تعررمن 
فقط المدن الخاصة بالمحافظة التي اختارها المستخدم في الخانة المجاورة لها. 

نحن نتكلم هنا عن أعمدة من النوع «DataGridViewComboBoxColunan‏ 
وهي تمتاز بأن خاناتها تعرض قائمة مركبة :00160130 في وضع التحرير 
Mode‏ 801» لكي يختار المستخدم منها قيمة معينة.. وقد رأينا كيف يمكننا في 
الوضع العادي ربط العمود بمصدر بيانات باستخدام الخصائص: 

DataGridViewComboBoxColumn. DataSource - 
DataGridViewComboBoxColumn. DisplayMember - 
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DataGridViewComboBoxColumn. Value Member -‏ 
ما يحدث فعليا هو أن العمود يضع قيم هذه الخصائص في خصائص كل خانة من 
خاناته.. هذه الخانات من النوع «DataGrid ViewComboBoxCel|‏ 
وههي الحا تمنلك الخصائص DisplayMembers DataSource‏ 
وalueMember..‏ هذا معناه أنك تستطيع تغيير مصدر بيانات كل خانة على 
حدة.. لكن ما يفعله العمود هو أنه يضع قيم هذه الخصائص في الخانة التي تعيدها 
الخاصية ..DataGridViewComboBoxColumn.Cell Template‏ 00 

الخانة تعمل كقالب افتراضي لكل الخانات الجديدة التي تضاف في هذا العمود.. 
يقوم العمود بتغيير قيم هذه الخصائص في الخانات القديمة. 
إذن» كيف يمكن تغيير قائمة أسماء المدن» عند تغيير اسم المحافظة؟ 
يمكن فعل هذا باستخدام الحدث »GataG rid View.Cell[ValueChanged‏ الذي 
ينطلق عند تغير قيمة أي خانة من خانات جدول العرض (لا يقع التغيير إلا بعد 
مغادرة الخانة بالفعل).. في هذا الحدث سنفحص قيمة المعامل e.Column1Index‏ 
للتأكد أن الخانة التي تغيرت قيمتها تقع في العمود الخاص بالمحافظات.. (وليكن 
رقم ×): 

If e.ColumnIndex = X Then 


©we©cccccccccecccccceeceoee 


فإن كان هذا الشرط صحيحاء فسنتبع الخطوات التالية: 
- سنحصل على الصف الحالي باستخدام رقم الصف 120181106:2.» كالتالي: 
Dim Row = DataGridView1.Rows(e.RowIndex)‏ 
- سنحصل على خانة اسم المحافظة باستخدام رقم العمود × كالتالي: 
Dim Cell = Row(e.RowIndex).Cells(X)‏ 
- سنعرف رقم المحافظة التي اختارها المستخدم باستخدام الخاصية عں[ه/ للخانة 
كذ ee‏ أنك ا الخاصية N‏ تشير إلى الخاصية (11 
Dim GovID = CType(Cell.Value, Integer)‏ 
- اكتب الكود المناسب للحصول أسماء مدن هذه المحافظة.. افترض أن النتيجة 
العائدة هي مجموعة اسمها 01165.. نريد أن نستخدم هذه المجموعة كمصدر 
بيانات الخانة المجاورة للخانة الحالية (رقم 1 + 72). 
عرف متغيرا لخانة أسماء المدن.. يجب تحويل نوع هذا المتغير من نوع الخانة 
العامة DataGrid view] e11‏ الى الن وع المح دد 
11 دندنلكلتى يمكننا استخدام خصائص ربط 
البيانات الخاصة بهذا النوع من الخانات: 
Dim CityCell As DataGrid ViewComboBoxCell =‏ 
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Row.Cells(X + 1)‏ 
CityCell.DataSource = Cities‏ 
CityCell.DisplayMember = "Name"‏ 
CityCell. Value Member = "ID"‏ 
بهذه الطريقة كلما غير المستخدم اسم المحافظة في أي صف» ستعرض خانة اسم 
المدن قائمة فيها أسماء مدن هذه المحافظة فقط. 
لاحظ أن ترتيب صفوف جدول العرض يؤدي إلى ضياع قيم خصائص ربط 
البيانات من كل خانةء لأن جدول العرض يستخدم القالب مهام ٥٠11١٠١٣‏ لإعادة 
رسم الخانات بعد عملية الترتيب.. وهذا سيجعل أسماء المدن التي اختارها 
المستخدم تختفي من كل خانات العمود (رغم أن أرقام المدن ما زالت محفوظة في 
الخانات» لكن لا يمكن عرض أسمائها بدون مصدر بيانات)! 
لهذا إما تمنع المستخدم من ترتيب الصفوف عند ضغط الأعمدة» وذلك بتغير قيمة 
الخاصية 50113810016 في كل عمود.. وإما أن تستخدم الحدث 50160 الذي ينطلق 
بعد تمام عملية الترتيب» لتمر عبر كل صفوف الجدول» وتعيد وضع مصدر بيانات 
خانات المدن تبعا للمحافظات المحددة في كل صف! 
وهناك حل ثالث؛ هو أن تجعل العمود يشير إلى مصدر بيانات يحتوي على كل 
أسماء المدن بغض النظر عن المحافظات.. في هذه الحالة سيوضع هذا المصدر في 
قالب الخانة «Cell Template‏ وعند الترتيب سيتم وضعه في كل خانات المدن» 
وبهذا ستظل أسماء المدن التي اختارها المستخدم ظاهرة. . لكن لو ضغط المستخدم 
الخانة وعرض القائمة المركبةء فسيري فيها كل أسماء المدن. لهذا عليك أن 
تستخدم الحدث 1عم115ع1233011011/161.0 الذي ينطلق عند دخول الخانة» 
لتعيد للخانة مصدر البيانات الصحيح تبعا للمحافظة المحددة. 
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سد وا ةَ أداة الد 
IDataGrid ViewEditingControl Interface‏ 


تعرّف هذه الواجهة العناصر المشتركة بين أدوات التحرير المستخدمة في خانات 
جدول العرضء وهي تملك الخصائص التالية: 


وخ جدول العرض :EditingControlDataGrid View‏ 
تق رأ أو تغير كائن جدول العرض :1233011017167 الذي يعرض اداة 


التحرير. 


وخ القيمة المنسقة :EditingControlFormatted Value‏ 
تقرأ أو تغير القيمة المنسقة المعروضة حاليا في أداة التحرير. 


و- رقم الصف :EditingControIRowIndex‏ 
تقرأ أو تغير رقم الصف الذي تظهر فيه أداة التحرير. 


وخ القيمة تغيرت :EditingControlValueChanged‏ 
اجعل قيمة هذه الخاصية مںإ1» إذا تغيرت القيمة المكتوبة في أداة التحريرء 
عن قيمة الخانة التي تعرض أداة التحرير. 


"57 ف مؤشر لوحة التحرير :Editing Panel Cursor‏ 
تعيد كائناء يحتوي المؤشر 00501) الذي يتم عرضه عندما تمر الفارة فوق 


اللوحة 7261 التي تحتوي على أداة التحرير. 


2 بر تغير موض عذأداة التحريير عند تغيرالقيمة 
:RepositionEditingControlOnV alueChange‏ 

تعيد 716 إذا كانت أداة التحرير بحاجة إلى تغيير موضعها بعد قيام 

المستخدم بالكتابة فيها.. على سبيل المثال: قد يكتب المستخدم نصا طويلا في 


أداة التحرير» مما يستلزم أن تقوم بتقسيمه على أكثر من سطر. 


كنا شتلك هذه الواحية الوسائل الاه 


1T 


7# تطبيق طراز الخانة على أداة التحرير :‘ApplyCellStyleToEditingContro1‏ 
تجعل لأداة التحرير الخصائص الشكلية الخاصة بكائن طراز الخانة 
1101151 الذي ترسله إليها كمعامل. 


#> هل تريد أداة التحرير زر الإدخال :EditingControl!WantsInputKey‏ 
تعيد 116 إذا كان الزر المرسل كمعامل هو أحد الأزرار التي تتعامل معها 
أداة الإدخال» سواء كان حرفا يمكن كتابته» أو وظيفة يمكن أن تؤديها.. أما إذا 
كانت أداة الإدخال لا تتعامل مع الزرء فإنها تعيد 12156 لتوضح أن على 
جدول العرض التعامل مع هذا الزر.. ولهذه الوسيلة معاملان: 

- المعامل الأول يستقبل إحدى قيم المرقم وره التي تعبر عن الزر 
المضغوط. 

- والمعامل الثاني معامل منطقيء إذا كانت قيمته 1116 فهذا معناه أن 
جدول العرض يمكنه التعامل مع الزر المضغوط. 


)> معرفة القيمة المنسقة :GetEditingControlFormatted Value‏ 
إحدى قيم المرقم 2:)5ع1031301101/161102121111010001 التي توضح 
محتوى الخطأ الخاص بالخانة. 


7# تجهيز أداة التحرير للتحرير 052610150110016 1056ل 15ع:7ومء:ط: 
تجهز الأداة عند بدء وضع التحريرء وهي تستقبل معاملا منطقياء إذا جعلت 
قيمته 116 فسيتم تحديد النص المكتوب في أداة التحرير. 


وقدأنش أنا الفقفة ]endarFditingControاCa‏ في المشروع 
21 وجعانااتمثٿ ل الواجهة 
01107161010001 لكي تكون أداة تحرير نستطيع استخدامها 
في جدول العرض. . ولكي نجعلها تعرض أداة اختيار التاريخ في الخانة التي 
تستضيفها» »لم نكتب أكثر من سطر واحد فقط يجعلها ترث الأداة ‘DateTimePicker‏ 
Class CalendarEditingControl‏ 
Inherits Date TimePicker‏ 
Implements [DataGrid ViewEditingControl‏ 
الكود الذي يمثل خصائص ووسائل الواجهة ' 
IDataGridViewEditingControl‏ ' 
End Class‏ 
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8 فئة أداة تحري مريع النص 
DataGridViewTextBoxEditingControl‏ 

هذهالففة ترت الففة »1٥×)80×‏ كما أنهاتمئلالواجهة 
0111:01 1182 م مما يعني أنها مربع نص مخصص 
للظهور في خانات جدول العرض عند تحريرهاء للسماح للمستخدم بالكتابة في 
الخانة. 

ولا تمتلك هذه الفئة أية عناصر أو خصائص جديدة» غير ما ترثه من الفئة الأم» 
وما تمثله من عناصر الواجهة .IDataGridViewEditingContro]‏ 


فئة أداة تحرير القائمة المركبة 
DataGrid ViewComboBoxEditingControl Class‏ 
هذ الففة ترث الفنة 01302 روه ): كما أنها تمثل الواجهة 
[DataGrid ViewEditingControl‏ مما يعني أنها قائمة مركبة مخصصة 
للظهور في خانات جدول العرض عند تحريرهاء للسماح للمستخدم باختيار قيمة 


ا 
ولا تمتلك هذه الفئة أية عناصر أو خصائص جديدةء غير ما ترثه من الفئة الأم؛ 
وما تمثله من عناصر الواجهة .IDataGridViewEditingContro]‏ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 
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فئة الخانة الرئيسية 
DataGrid ViewHeaderCell Class‏ 


هذه الفنة ترث الفئة 1(0342011015/161:0611: وهي تعمل كفئة أم تحتوي على 
الخصائص والوسائل المشتركة بين خانة رأس العمود وخانة رأس الصف. 

ولا تمتلك هذه الفئة أية خصائص أو وسائل جديدة غير ما ترثه من الفئة الأم.. قد 
يبدو لك هذا غريباء لكن فائدة هذه الفئة تتضح حينما تريد أن تنشئ خانة رئيسية 
خاصة بك تعرض أيقونة أو مقبضا أو لها شكل خاصء ففي هذه الحالة عليك أن 
تنشئ فة ترث الفئة »Data6G ri) View] e2 e1٣ e11‏ وتضيف إليها القدرات 
الجديدة التي تريدها. 


8 فة خانة رأس العمؤد 
DataGrid ViewColumn HeaderCell‏ 


هذه الفئة ترث الفئة 11٣1ء »DataG rid View Head‏ وهي تعمل كخانة تعرض 
عنوان أحد الأعمدة في جدول العرض. 
وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخاصية التالية: 


و- اتجاه الترتيب :SortGlyp h Direction‏ 
تحدد اتجاه الصورة الرمزية 1م0617 التي يعرضها العمود لتوضح طريقة 
ترتيبه» وهي تأخذ إحدى قيم المرقم 5010106 التالية: 


22106 |العمود غير مرتب (لا تظهر أي صورة). 
Ascending‏ العمود مرتب تصاعديا (صورة مثلث رأسه إلى أعلى). 
Descending‏ العمود مرتب تنازليا (صورة مثلث رأسه إلى أسفل). 
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8 فة الخانة العلوبة السرم 
DataGrid ViewTopLeftHeaderCell‏ 


هذه الفئة ترث الفئة 11ع »DataG rid ViewColumn 1e2 er٣‏ وهي تمثل الخانة 
العلوية اليسرى في جدول العرضء والتي عند ضغطها يتم تحديد كل خاناث 
الجدول. 


ولا تمتلك هذه الفئة أية خصائص أو وسائل جديدة غير ما ترثه من الفئة الأم. 


ع 


5# فئة خانة رأس الصف 
DataGrid View RowHeaderCell‏ 





هذه الفنة ترث الفئة DataGridView ead er ٥11‏ وهي تعمل كخانة رأس 
لأحد صفوف جدول العرض» وعند الضغط عليها يتم تحديد هذا الصف. 


ولا تمتلك هذه الفئة أية خصائص أو وسائل جديدة غير ما ترثه من الفئة الأم. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والديّ كما ربياني صغيرا 
آمين يا رب العالمين 
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42 فئة طراز خانة جدول العرض 
DataGrid ViewCellStyle Class‏ 


هذه الفئة تمثل الواجهة عااوعمه[٤]»‏ وهي تحمل معلومات التنسيق والشكل 
الخاص بإحدى خانات جدول العرض. 
ولحدث إنشاء هذه الفئة صيعتان: 
-١‏ الصيغة الأولى بدون معاملات. 
؟- والصيغة الثانية تستقبل كائن طراز خانة DataGrid ViewCe1IStyle‏ 
لكام تخصائصيه كليم ميدئية للكائن الحالي, 


وتمتلك هذه الفئة بعض الخصائص الشهيرة المألوفة لناء مثل: 


3 الهامش الخارجي 722300105 “ا لون الخلفية BackColor‏ 
5 لون الكتابة 010 F۴0٣eC‏ “5 الخط Font‏ 
وخا الوسم ع1'2' 


كما تمتلك هذه الفئة الخصائص التالية: 


وخ المحاذاة :Alignment‏ 
تحدد كيفية محاذاة محتويات الخانة» وهي تأخذ إحدى قيم المرقم 
hata GridViewContentAlignment‏ التالية: 


NotSet‏ المحاذاة غير محددة. 
TopLeft‏ أعلى اليسار. 
r opCenter‏ | أعلى الوسط. 
أطع1خ1م10 | یمین الوسط. 
MiddleLeft‏ | يسار الوسط. 

Mid dleCenter‏ | منتصف الوسط. 
MiddleRight‏ | یمین الوسط. 
Bottom Left‏ | أسفل اليسار. 
Center‏ | أسفل الوسط, 
BottomRight‏ | أسفل اليمين. 
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3 تنسيق :Format‏ 
تستقبل نصا يمثل الصيغة التي ستستخدم لتنسيق محتويات الخانة. . لمزيد من 
التفاصيل عن صيغ التنسيق» راجع ملاحق كتاب برمجة إطار العمل. 


3 مزود التنسيق :FormatProvider‏ 
هذه الخاصية من النوع 0v¡d er‏ 2۴ص0 1۴ء وهي تستقبل كائن معلومات 
الثقافة مÊمآعإںاآاں؛‏ الذي يحوي معلومات عن اللغة والمنطقة التي 
ستستخدم قواعدهما في تنسيق الأرقام والتواريخ والنصوص.. وفي الوضع 
الافتراضي» تخد هذه الخاصيية الثقافة المحلية الخاضة يجهاز المستخدم. 


“57 فط هل لمزود التنسيق القيمة الافتراضية :IsFormatProvider Default‏ 
تعيد م151 إذا كانت للخاصية 1ع1"01314210710 القيمة الافتراضية» وتعيد 
156 إذا كنت وضعت قيمة أخرى في تلك الخاصية. 


3 القيمة المنعدمة لمصدر البيانات :DataSourceNulIValue‏ 


ضع في هذه الخاصية القيمة التي تريد حفظها في مصدر البيانات» إذا ترك 
المستخدم الخانة الحالية فارغة.. والقيمة الافتراضية لهذه الخاصية هي العدم 


.DbNull 


7 يخ مهل القيمة المنعدمة لمصدر البيانات افتراضية 
:IsDataSourceNullV alueDefault‏ 
تعيد عنم[ إذا كانت للخاصية DataSourceNul[ Value‏ القیمة 
الافتراضيةء وتعيد 12156 إذا كنت وضعت قيمة أخرى في تلك الخاصية. 


وخ القيمة المنعدمة :NulIValue‏ 

ضع في هذه الخاصية كائنا )»٥زط0‏ يحمل القيمة التي تريد عرضها عندما 
تكون الخانة فارغة أو تحتوي على القيمة المنعدمة 2107011].. كما أن قيمة 
هذه الخاصية ستكون هي القيمة الافتراضية للخانات التي تضاف جديدا إلى 
العمود الذي له الطراز الحالي.. مثال: 

Gdv.Columns(0).DefaultCellStyle. NullValue = "...."‏ 
ها الكود سيجعل التصس "...” هو القيسة المتعدمة لخانات العمود الأول في 
حدول العركن: ايذا سيطون النحى*. "كن آخر خا فى هذا العمود 
(الموجودة في الصف الجديد). 1 1 
لاحظ أن المستخدم يستطيع وضع القيمة المنعدمة في الخانة أثناء تحريره لها 
بضغط 1+0') من لوحة المفاتيح. . في هذه الحالة سيتم محو كل محتويات 


11۹ 


العانة وضع قيمة هذه الخاصية نها والقيمة الافتزاضية لهذم الخاصية هي 
نص فارع 0 

57 ف هل القيمة المنعدمة افتراضية :IsNulIValue Default‏ 
تعيد مں ٣٣‏ إذا كانت للخاصية 71011172106 القيمة الافتراضيةء وتعيد عی[ھ۴٣‏ 
إذا كنت وضعت قيمة أخرى في تلك الخاصية. 


لون خلفية التحديد :SelectionBackColor‏ 
تقرأ أو تغير لون خلفية الخانة المحددة 1[ع0 0عاءه1ء56. 


ونج لون النص المحدد :SelectionForeColor‏ 
تقرأ أو تغير لون النص في الخانة المحددة. 


وخا طريقة الالتفاف :Wrap Mode‏ 
توضح هل سيلتف النص على أكثر من سطر إذا تجاوز عرض الخانة أم لا 
وهي تأخذ إحدى قيم المرقم ه1115 (a) 614 ۷1ew‏ الذي تعرفنا عليه 
من قبل. 


كما تملك هذه الفئة الوسيلة التالية: 
2# تطبيق الطراز 01956916مخ: 


أرسل إلى هذه الوسيلة كائن طراز الخانة DataGrid ViewCel1IStyle‏ 
الذي تريد نسخ قيم خصائصه إلى خصائص الكائن الحالي. 


0 


#© فة طراز الحافة المتطو 
DataGridViewAdvancedBorderStyle Class‏ 


هذه الفئة تمثل الواجهة 10105262616» وهي تحمل معلومات عن شكل إطار إحدى 
وتمتلك هذه الفئة الخصائص التالية: 


كل الحواف 411: 
تحدد طراز جميع حواف الخانة» وهي تأخذ إحدى قيم المرقم 
hata GridViewAdvancedCel1BorderStyle‏ التالية: 


NotSet‏ غير محدد. 


None‏ بدون حافة. 
Single‏ خط مفرد. 
Inset‏ خط غائر. 


11 | خط مزدو ج غائر. 
Outset‏ خط بارز. 

6 )| خط مزدوج بارز. 

11 | خط مفرد به جزء مرتفع. 











وخ الحافة العليا 100: 
مماثلة للخاصية السابقة» إلا أنها تتعامل مع الإطار العلوي للخانة. 


“7 الحافة السفلية د«ره)]190: 
مماثلة للخاصية السابقةء إلا أنها تتعامل مع الإطار السفلي للخانة. 


37 الحافة اليسرى 1.6]6: 
مماثلة للخاصية السابقةء إلا أنها تتعامل مع الإطار الأيسر للخانة. 


'7 الحافة اليمنى )1ع 121: 
مماثلة للخاصية السابقةء إلا أنها تتعامل مع الإطار الأيمن للخانة. 


1۳1 





























شبكة البيانات 1(212)071:10 


تعمل هذه الأداة كجدول يعرض أعمدة وصفوف» ويمكن ربطه بمصادر البيانات» 
بنفس الطريقة التي رأيناها في الأداة /103]801105/16. 

ورغم أن الأداة 1(34301105/166 تمتلك قدرات أكثر من هذه الأداة» وتمنحك 
تحكما كاملا في كل أجزائهاء وتتيح لك إنشاء أنواع جديدة من الخانات على حسب 
احتياجك» إلا أن شبكة البيانات تمتاز بخاصيتين لا توجدان في جدول العرض: 

-١‏ وجود عدة طرازات و5616 جاهزة تمكنك من اختيار شكل الجدول 
مباشرة في وقت التصميم. 

؟١-‏ قدرة شبكة البيانات على عرض الجداول المترابطة معا بطريقة تشبه 
cAccess‏ حيث يعرض كل صف في الجدول الرئيسي العلامة +» وعند 
ونظرا لأن الأداة سع ز۷إ 6ه)هD‏ لا تملك مثل هذه الخاصيةء فإن عليك 
أن تستخدم أداتين منها لعرض الجدول الأصلي والجدول الفرعي» بإضافة 
عمود أزرار إلى الجدول الرئيسي» وعند ضغط أي زرء يتم عرض نموذج 
جديد به جدول عرض يحتوي على السجلات الفرعية»ء كما فعلنا في 
المشروع 1221201101/161411]011830015.. أو يمكنك عرض الجدول 
الفرعي في نفس النموذج أسفل الجدول الرئيسيء وقد رأينا كيف نفعل هذا 
في المشروع .DataGrid ViewMasterDetails‏ 

ونظرا لأهمية الخاصية الثانيةء والتي قد تدفعك إلى استخدام شبكة البيانات في 
الأداة ١1034203130‏ وهي على كل حال« ليست بضخامة الأداة .DataGrid View‏ 
وعليك إضافة هذه الأداة أولا إلى صندوق الأدوات» بالضغط بزر الفأرة الأيمن في 
أي موضع تحت الشرط 1(38؛» وضغط الأمر 166175 50056©» ومن ثم اختيار 
العنصر 10343001101 من قائمة الأدوات» مع التأكد أن العمود الثاني في القائمة 
يشير إلى أن العنصر الذي اختره ينتعي إلى النطاق 
System. Windows.Forms‏ لأن هناك أداة شبكة بيانات أخرى خاصة 
بتطبيقات الويب. 
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ت واجهة خدمة التحرير 
IdataGridEditingService Interface‏ 


تمنح هذه الواجهة مستخدم شبكة البيانات القدرة على تحرير خاناته» وهي تملك 
الوسيلتين التاليتين: 


بدء التحرير :Begin Edit‏ 
تبدأ تحرير خانة في شبكة البيانات» وهي تستقبل المعاملين التاليين: 
- كائن طراز العمود ع1101561 1233011000 الذي يمثل العمود 
الذي توجد به الخانة المراد تحريرها. 
- رقم الصف الذي توجد به الخانة المراد تحريرها. 
وتعيد هذه الوسيلة 106 إذا نجحت في بدء التحرير. 


إنهاء التحرير 10220110016: 
تنهي تحرير خانة في شبكة البيانات» وهي تستقبل المعاملين التاليين: 
- كائن طراز العمود 10318001100011110516716 الذي يمثل العمود 
الذي توجد به الخانة المراد تحريرها. 
- رقم الصف الذي توجد به الخانة المراد تحريرها. 
- معامل منطقي إذا جعلته 1'16؛ فسيتم إلغاء القيمة الجديدة التي تم 
تحريرهاء والعودة إلى القيمة الأصلية للخانة.. أما إذا جعلتها 21156 
فسيتم حفظ القيمة الجديدة في الخانة. 
وتعيد هذه الوسيلة مآ إذا نجحت في إنهاء التحريرء وتعيد ع15 إذا 
فشلت في حفظ قيمة الخانة» وفي هذه الحالة تظل الخانة في وضع التحرير. 
اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم انصر المسلمين في كل مكانء 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


تنا 


2 فئة طراز شبكة البيانات DataGrid 1ab1eStyle Class‏ 


هذه الفئة ترث الفئة غعم0م0022)»: وتمثل الواجهة «IdataGridEditingService‏ 
وهي تتيح لك التحكم في شكل الجدول الذي ترسمه الأداة 30110 عند عرض 
البيانات. 
ولحدث إنشاء هذه الفئة الصيغ التالية: 
-١‏ الصيغة الأولى بدون معاملات. 
بك السيعة الكانية تبقل ماماد محلا !ذا ج تة عو فقي هذا 
إلى أن طراز الجدول الحالي هو الطراز الافتراضي. 
۳- الصيغة الثالثة تستقبل مدير التداول ع2٣2‏ yNء١ءإإu‏ الذي يتحكم في 
الارتباط بمصدر البيانات» ليستخدمه طراز الجدول فى إنشاء الأعمدة 
وعرض البيانات فيها. ۰ 


ا شبكة البيانات :Da)46 ¡1d‏ 
تقرأ أو تغير كائن شبكة البيانات 1726200110 الذي يستخدم طراز الجدول. 


3 اسم الخريطة :MappingName‏ 
ضع في هذه الخاصية اسم عنصر البيانات الذي يعرضه طراز الجدول 
الحالي؛ وفي الغالب سيكون اسم أحد جداول مجموعة البيانات» مثل 
Auth"‏ ".. هذا يتيح لك استخدام أكثر من طراز جدول في شبكة البيانات؛ 
كل منها بعر کن جدولا من جداول قاغدة البيانات :: بشكل وألوان وتنسيق خاصة 
به 


57 ف طرازات أعمدة الجدول :GridColum Styles‏ 
تعيد مجموعة طرازات أعمدة الجدول «Grid ColumnStylesCollection‏ 
وهي ترث الفئة 10]ع835600116: كما أنها تمثل واجهة القائمة 156.]].. 
وتحتوي هذه المجموعة على عناصر من النوع «DataGridColumnStyle‏ 
کا ا ا عب المرسومة في طرار الحدون الخال و وة 
على الفئة DataGrid ColumnStyle‏ لاحقا. 


عناوين الأعمدة مرئية 16[طزو0116206125571دسد[ه0©: 
إذا جعلت قيمة هذه الخاصية 156 (وهي القيمة الافتراضية)؛ فسيتم عرض 
صف رؤوس الأعمدة. 


وجا عناوين الصفوف مرنئية :RowHeaders Visible‏ 
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إذا جعلت قيمة هذه الخاصية 1516 (وهي القيمة الافتراضية)» فسيتم عرض 
عمود رؤوس الصفوف. 


الع العرض المفضل للعمود :PreferredColumnWidth‏ 


نفرا اح شرا کے اللاي سلاخذه الأصدة عند ای 
الجدول الحالي, 


وخ الارتفاع المفصJ‏ للصفوف :Preferred RowHIeight‏ 
تقرأ أو تغير الارتفاع المبدئي الذي ستأخذه الصفوف عند إنشائها في طراز 
الجدول الحالي. 


3 عرض عناوين الصفوف :RowHecader Width‏ 
تقرأ أو تغير عرض عمود رؤوس الصفوف. 


و- للقراءة فقط :و[206©(2»ع12: 
إذا جعلت قيمة هذه الخاصية 1516» فلن يتمكن المستخدم من تغيير قيمة أي 
خانة في طراز الجدول الحالي. 

وخ السماح بالترتيب ع411015501)1 : 
إذا جعلت قيمة هذه الخاصية 16[ "» فسيتمكن المستخدم من ترتيب صفوف 
الجدول تبعا للعمود الذي يضغط خانة عنوانه. 

أ لون الخلفية :010 1326140: 
تقرأ أو تغير لون خلفية الصفوف الزوجية في شبكة البيانات. 

وخ لون الخلفية التبادلي :Alternating BackColor‏ 
تقرأ أو تغير لون خلفية الصفوف الفردية في شبكة البيانات. 


“5 لون النص :010 160م"1: 
تقرأ أو تغير اللون المستخدم في كتابة نصوص الخانات. 


ونج لون خلفية التحديد :SelectionBackColor‏ 
تقرأ أو تغير لون خلفية الخانات المحددة. 


1o 


“نا نون نص التحديد :SelectionForeColor‏ 
تقرأ أو تغير لون نصوص خلفية الخانات المحددة. 
أ لون خطوط الشبكة :GridLineColor‏ 
تقرأ أو تغير لون الخطوط الفاصلة بين الصفوف والأعمدة. 
وخ طراز خطوط الشبكة ©71ج1101.1065)0©: 
تتحكم في شكل الخطوط الفاصلة بين الصفوف والأعمدة» وهي تأخذ إحدى 
قيمتي المرقم ©173120130110651671 التاليتين: 


6م270 | لا يتم رسم خطوط الشبكة. 
4 | يتم رسم خطوط الشبكة. 











5 لون خلفية العناوين :HeaderBackColor‏ 
تقرأ أو تغير لون خلفية خانات عناوين الأعمدة والصفوف. 


وا لون نصوص العناوين ‘-HeaderForeColor‏ 
ال خط العناوين :HeaderFont‏ 
تقرأ أو تغير خط الكتابة المستخدم في خانات عناوين الأعمدة والصفوف. 


ال لون الروابط :1.1212)'0101: 
تقرأ أو تغير لون نصوص الوصلات 1.1015 الموجودة في خانات الجدول. 


3 لون التحليق فوق الروابط :LinkHoverColor‏ 
تقرأ أو تغير لون نصوص الوصلات وم الموجودة في خانات الجدول» 
عند التحليق فوقها بالفأرة. 
وتمتلك هذه الفئة عدة وسائلء لكنها غير هامةء فكلها تبدأ بالكلمة 126561 متبوعة 
باسم إحدى الخصائصء ومهمتها إعادة قيمة تلك الخاصية إلى قيمتها الافتراضية» 
مثل .ResetBackColor‏ | 
كما تمتلك هذه الفئة عدة أحداث؛ لكنها كلها تنطلق عند تغير قيمة إحدى 
الخصائصء مثل الحدث 0ع Row Header Width Chan‏ الذي ينطلق عندما 
يتغير عرض عمود رؤوس الصفوف. 


© واجهة التنبيه بتحرير عمود شبكة البيانات 


مرا 











IDataGridColumnStyleEditingNotificationService Interface 


تنبه هذه الواجهة عمود شبكة البيانات بأن هناك أداة تحرير تستخدم حاليا مع إحدى 
خاناته» وهي تمتلك الوسيلة التالية: 


7# بدء تحرير العمود :ColumnStartedEditing‏ 
تخبر شبكة البيانات بأن المستخدم بدأ تحرير إحدى الخانات» ولها معامل واحد 
من النوع 00:01©» يستقبل أداة التحرير المستخدمة في الخانة. 


2 فئة طراز العمود DataGrid ColumnStyle‏ 


هذه الفئة أساسية مجردة 601255 8356 ]855030 تجب وراثتهاء وهي 
تقرث الفنة «Component‏ كما أنها تمئلالواجهة 
..[DataGridColumnStyleEditingNotificationService‏ وتعمل الفئات 
المشتقة من هذه الفئة كأعمدة في شبكة البيانات» كما أنها تتحكم في شكل وتنسيق 
خانات هذه الأعمدة. 


وتمتلك هذه الفئة الخصائص التالية: 


57 فز طراز شبكة البيانات b1eStyleۆa‏ 1 :DataGrid‏ 
تعيد كائن طراز الجدول ع103:201101361656:1: الذي يحتوي على كائن 
طراز العمود الحالي. 


3 المحاذاة :Alignment‏ 
تحدد محاذاة النص في خانات العمود» وهي تأخذ إحدى قيم المرقم 
HorizontalAlignment‏ التالية: .Center - Right - Left‏ 


]ا عنوان العمود )بره 11630611 
ر ار فر النص المعروطن في عا وخ الود 

وخ اسم الخريطة :MappingName‏ 
تحدد اسم عنصر البيانات Data Menaber‏ الذي يعرضه طراز العمود.. 
وفي الغالب تحتوي هذه الخاصية على اسم أحد أعمدة مجموعة البيانات. 


1۷ 


النص المنعدم 2]111'624: 
كع في هذه الخاصية النصن الذي كرض بكافاك الغدرة إذا كانت قار عة 


وخ للقراءة فقط رارم 4140ء :R‏ 
إذا جعلت قيمة هذه الخاصية ع11» فلن يستطيع المستخدم تغيير قيمة أية 
خانة في العمود الحالي» والقيمة الافتراضية هي ع1'215. 


العرض :W 10٤1‏ 
تقرأ أو تغير عرض العمود الحالي. 

وخ واصف الخاصية :PropertyDescriptor‏ 
تقرأ أو تغير كائن واصف الخاصية 1601م1071(65611ع م220 الذي يحوي 
على سمات العمود.. هذا يمكنك من تحديد نوع البيانات التي يقبلها العمود. 


وقمتلك هذه الفقة الوسيلة التانية: 


#> تصفير عنوان العمود :ResetHeader Text‏ 
تعيد الخاصية )زع 20611ع21 إلى قيمتها الافتراضية» وهي نص فارغ "". 


كما تمتلك هذه الفئة مجموعة من الأحداث» أهمها الحدث التالي: 


۶ العرض تغير :WidthChanged‏ 
ينطلق إذا تغير عرض العمود. 


TA 


42 فئة عمود النتصوص DataGridTextBoxColumn Class‏ 


هذه الفئة ترث الفئة 1(3132011000110351:16» وهي تمثل عمودا في شبكة 
البياناك تعر کن كاتاثه تضم ضا 
ولحدث إنشاء هذه الفئة الصيغ التالية: 
-١‏ الصيغة الأولى بدون معاملات. 
؟- الصيغة الثانية تستقبل واصف الخاصية 1601م6171065011م2120 المستخدم 
مغ الغفوة الحالى. 
۳- الصيغة الثالثة تزيد على الصيغة السابقة بمعامل مذ منطقي »> اذا جعلته عںإآ 
فسيتم اعتبار العمود الحالي عمودا افتراضيا .Default Colunn‏ 
-٤‏ الصيغة الرابعة تزيد على الصيغة الثانية بمعامل نصيء يستقبل الصيغة 
الخدم فى تشن النصوسن فى كانات الحو ٠‏ 
5- الصيغة الخامسة تزيد على الصيغة السابقة بمعامل منطقيء إذا جعلته 
م" فسيتم اعتبار العمود الحالي عمودا افتراضيا .Default Column‏ 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخصائص التالية: 


وخا التنسيق 1”01:1221: 
ضع فى هذه الخامية نصا يحل الضيعة الميتكدية لتسيق كانت امود 


وخ معلومات التنسيق 1”01:1212111210: 
هذه الخاصية من النوع 11"0112124210510161» وهي تستقبل كائن معلومات 
الثقافة «CultureInfo‏ الذي يحوي معلومات عن اللغة والمنطقة التي 
ستستخدم قواعدهما في تنسيق الأرقام والتواريخ والنصوص.. وفي الوضع 
الافتراضي» تستخدم هذه الخاصية الثقافة المحلية الخاصة بجهاز المسة لمستخدم. 


57 فز مربع النص 16201502: 


تعيد كائن مربع النص ×80×ع1٠‏ الذي يستضيفه العمود الحالي ويعرضه 
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4 فئة العمود المنطقي Class‏ 102420211010010-011111112 


هذه الفئة ترث الفئة 1(31300110001103251716» وهي تمثل عمودا في شبكة 
البيانات تعرض خاناته مربع اختيار :1ه15عع0» ليمثل القيم المنطقية مهدءع2001. 
ولحدث إنشاء هذه الفئة الصيغ التالية: 

-١‏ الصيغة الأولى بدون معاملات. 

؟- الصيغة الثانية تستقبل واصف الخاصية 1601م 220611971065613 المستخدم 

مع الكموة الخال 
8 *- العسيغة الثالثة تزيد على الضصيعة السايقة عامل مني إذا حه ما 
فسيتم اعتبار العمود الحالي عمودا افتراضيا .Default Column‏ 


وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الفئة الخصائص التالية: 


السماح بالعدم 41101:111: 
إذا جعلت قيمة هذه الخاصية عوء[ه۴» فسيكون لمربع الاختيار حالتان فقط: 
Checked‏ و ..nchecked‏ والقيمة الافتراضية لهذه الخاصية هي 1:06 » 
وفي هذه الحالة سيكون لمربع الاختيار الحالة الثالنة غير المحددة 
[ndeterminate‏ اذا كانت قيمة الخانة 1111 106107. 


3 القيمة المنعدمة :NulIValue‏ 
ضع في هذه الخاصية القيمة التي تعتبر عدماء والتي ستجعل مربع الاختيار 
في الحالة غير المحددة.. يمكنك مثلا استخدام الرقم ١-‏ كمناظر للقيمة غير 
المحددة. 


وخا القيمة الخاطنئة ع7211١1"21567:‏ 
ضع في هذه الخاصية القيمة التي تعتبر ع1'015» والتي ستجعل مربع الاختيار 
في حالة عدم الاختيار 0ع>1[120161].. يمكنك مثلا استخدام الرقم صفر 
كمناظر للقيمة الخاطئة. 


ونج القيمة الصحيحة :TrueValue‏ 
ضع في هذه الخاصية القيمة التي تعتبر ©111[» والتي ستجعز ) مربع الاختيار 
في حالة الاختيار 160164©.. يمكنك مثلا استخدام الرقم ١‏ كمناظر للقيمة 
الخاطئة. 
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أ سجل خانة الشبكة 
DataGridCell Structure‏ 


يعمل هذا السجل كخانة في شبكة البيانات» ولحدث إنشائه معاملان: 
- رقم الصف الذي توجد به الخانة. 
- رقم العمود الذي توجد به الخانة. 


ويمتلك هذا السجل الخاصيتين التاليتين: 


وخ رقم الصف :RowNumber‏ 
تقرأ أو تغير رقم الصف الذي توجد به الخانة. 


وخ رقم العمود :ColumnNumber‏ 
تقرأ أو تغير رقم العمود الذي توجد به الخانة. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 
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4 فئة شبكة البيانات DataGrid Class‏ 





هذه الفقفةترث فة الأداة الأم 01مه0: وتمثل الواجهة 
©1511 وهي تمتلك الخصائص التالية: 


ونج مصدر البيانات ع1(242501011:2: 
ضع في هذه الخاصية الكائن الذي يعمل كمصدر للبيانات التي تعرضها شبكة 
البيانات» مثل مجموعة البيانات مهه( أو جدول البيانات 12231431216 أو 
عرض البيانات 1233597167 أو أية مجموعة تحتوي على كائنات بها 
خصبائمن اسا 


ونج عنصر البيانات :Data Member‏ 
طنع فى هذ الخاصدة اس عنصر انات العواة ركه يكل انمه يدون 
المؤلفين ."Authors"‏ 


57 ييز طرازات الجداول وع1'2165616: 

تعيد مجموعة طرازات الجداول مرمتاء»0110185165571650011: وهي 
ترث الفئة 835600011616100 وتمثل واجهة لقائمة ]11.15» وكل عنصر من 
عناصرها من النوع .GridTableStyles‏ 

ويمكنك إضافة العناصر إلى هذه المجموعة بشكل مرئي في وقت التصميم: 
وذلك اذا اف الخصائص» حيث يودي ضبعط الزن الموجوه فى خادة 
هذه الخاصصية إلى عرض التافذة الموضحة في الصورة: 

عدا 


Members: DataGridTableSty le1 properbes: 
0 E E2! 
5 Appearance = 
| GridlineStyle Sold 
5 HeaderFont Tahoma; Spt 
5 Behavior 
AllovSorting True 
85 Colors 
Alternating BackCol] Windows 
BackColor Ll] Window 
ForeColor | vindowsText 


GridLineColor Î] control 
HeaderBackColor لا‎ Control 
HeaderForeColor I ControlText 
LinkColor | HotTrack 
SelectionBackColoı ll Activecaption 


SelectionForeColor mi ActiveCaptionTexl 
__ Remove | 5 Data 9 


OK | Cancel | | 
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في هذه النافذة» يمكنك ضغط الزر Add‏ لإضافة طراز جدول جديدء» 
واستخدام الخصائص المعروضة في النصف الأيمن من النافذة للتحكم في 
خصائص هذا الطرازء وربطه بجدول البيانات باستخدام الخاصية 
..MappingName‏ كما يمكنك استخدام الخاصيّة Grid ColumnStyles‏ 
للتحكم في طراز أعمدة الجدول.. لفعل هذا اضغط زر الانتقال المجاور لهذه 
الخاصيةء لتظهر لك نافذة محرر مجموعة طرازات الأعمدة: 


ELC CIE ILRI CIT 2× 





Members: DataGrid BoolColu mn 1 properties: 
[0 DataGridTextBoxColu mn1 لض ع‎ 
1 DataGridBooColurmn1 E Data 5 
| 8 (AppkcationSettinç 
E Design 
(Name) DataGridBoaolColu 
Generateember True 
Modifiers Friend 
E Display 
Alghment Left 
HeaadarTaxt 
NullText (nul 
8 Layout 
Width 75 
8 Misc 
FalseVahıe False 
Mappingîlame 


ت س 0ك 

DataGridBoolColumn Ok | Cancel |‏ 
في هذه النافذة يمكنك إضافة طراز عمود جديد بضغط الزر ۸44.. لاحظ 
وجود سهم في جانب الزر ‘Add‏ ولو ضغطته بالفأرة فستظهر قائمة 
موضعية» تتيح لك اختيار نوع العمود الذي تريد إضافة طراز له» سواء كان 
عمود نصوص 0111130 »DataGri4 ۲ ex×180×€‏ أو عمودا منطقيا 
00100100 ..ويمكنك تغيير خصائص طراز العمود من 
النصف الأيمن للنافذة.. ولا تنس أن تضع في الخاصيّة MappingName‏ 
اسم العمود الأصلي الذي يعرض طراز العمود بياناته. 
كما يمكنك أن تحصل على تنسيقات جاهزة للجدول» وذلك بضغط شبكة 
البيانات بزر الفأرة الأيمن في وقت التصميمء واختيار الأمر AutoFormat‏ 
من القائمة الموضعيّة» حيث ستظهر لك نافذة تحتوي على قائمة بأسماء 
التنسيقات المتاحة» مع عرض نموذج لتأثير كلّ منها على جدول المعاينة. 
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Auto Format 6 


Formats: Preview: 





1 
2 


وخا السماح بالتصفح :AllowNavigation‏ 
إذا جعلت قيمة هذه الخاصية ع1:1' (وهي القيمة الافتراضية)» فستعرض 
ف البواناك الوصلات اى نقح لك امراش الجداول الف غي 
ويمكنك اختبار تأثير هذه الخاصية في التطبيق «DataGridNavigation‏ 
فلو شغلت هذا البرنامج فلن تظهر في الجدول أي بيانات.. وإنما ستظهر 
العلامة "+" ولو ضغطتها فستعرض لك اسمي جدولي المؤلفين والكتب. 


ا×ادا۔ 








Authors 
Books 





¥ AllowNavigation 





ولو أزلت علامة الاختيار من مرع الاختيار ١0زاوع¡ Nav‏ س ]ا۸ء فستختفي 
العلامة + واسما الجدولين» وسيظل جدول العرض فار غا! 

أعد وضع علامة الاختيار» واضغط اسم جدول المؤلفين 0۲۶ طاں۸.. سيمتلئ 
الجر ل بسحلات .جدول المؤلفين: رقي الماش العلوي لشيكة اليانات سسيظهر. 
اسم مجموعة البيانات.. لهذا سيكون مفيدا أن تعطي مجموعة البيانات اسما 
واضحا بدلا من الاسم الافتراضي ..NewDataSet‏ وقد أسميناها في هذا 
المشروع "قاعدة بيانات الكتب". 
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ا کل سحل من سالات لمرن رى الا رار خت هذه 
أعطيت العلاقة اسما واضحا للمستخدم بدلا من الاسم الافتراضي 
1 .م وقد أسميناها في هذا المشروع "كتب المؤلف": 


RS‏ ااتسهلتنا 


About | Phone | CountryID | Author | Dy 


(null) | 


OSO EE 


(null) 1 
(nullj 5١ فاروق جودة‎ 


MV AllowNavigation 





وأيضاء لو أزلت علامة الاختيار من مر ع الاختيار «AlIlowNavigation‏ 
فستختفي العلامة + وستظهر سجلات جدول المؤلفين بمفردها. 
اضغط اسم العلاقة بالفأرة.. سيت عرض أسماء الكتب الخاصة بهذا المؤلف. 


كما سيظير سجل هذا المؤلف» على الجدول: 
ادا !!!اهن 


:NewDataSet 
iT ID :Authors 


ClassID | PublisherID | > AuthorlD | Book |‏ 
الطحام لكل فم 15 
عصفور من الش 1١5‏ 





IV AllowNavigation 





الموجودة أعلى يسار الجدول» ولإعادة عرض هذا السجل» فاضغط نفس 


1.45 


العلامة مرة أخرى.. ولو أردت العودة إلى جدول المؤلفين» فاضغط السهم 
الموجود أعلى شبكة البيانات. 
لاحظ أن شبكة البيانات تعرض اسمي جدولي المؤلفين والكتب عند تشغيل 
البرنامج» لأننا ربطناه بمجموعة البيانات كلهاء ولو كانت فيها جداول أكثر 
لظهرت اسماؤها كلها: 
DataGrid1.DataSource = Ds‏ 
ولو أردت عرض جدول واحد فقط كجدول المؤلفين» فاستخدم الجملة التالية: 
DataGrid1.DataSource = Ds.Tables(" Authors'")‏ 
في هذه الحالة ستعرض شبكة البيانات سجلات جدول المؤلفين مباشرة» مع 
کور العلايسة + يهؤار كل سجل من سحلاته اكك عر ك السهلات 
الفرعية في جدول الكتب.. أما لو استخدمت الجملة التالية: 
DataGrid1.DataSource = Ds.Tables("'Books'")‏ 
فستعرض شبكة البيانات سجلات جدول الكتب فقطء ولن تجد أية طريقة 
لعرض أية سجلات من جدول المؤلفين. 


و- لون الأرضية :BackgroundColor‏ 


تقرأ أو تغير لون أرضية شبكة البيانات (الجزء الذي لا توجد فيه خانات). 


العنوان مرئي 16طزوز10857)مه©: 


إذا جعلت قيمة هذه الخاصية مء[ه۴؛ فلن يظهر شريط العنوان أعلى شبكة 
البيانات.. والقيمة الافتراضية لهذه الخاصية هي عں۲!. 


و- نص العنوان :Capti0 1 1 ex)‏ 


تقرأ أو تغير النص المعروض في شريط العنوان. 


وخ لون خلفية العنوان :CaptionBackColor‏ 


تقرأ أو تغير لون خلفية شريط العنوان. 


وخ لون نص العنوان :CaptionForeColor‏ 


تقرأ أو تغير لون النص المعروض في شريط العنوان. 


وخ خط العنوان :CaptionF'ont‏ 


تقرأ أو تغير الخط المستخدم لكتابة النص المعروض في شريط العنوان. 
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وخ رقم الصف الحالي :CurrentRowIndex‏ 
تقر أو تغير رقم الصف المحدد حاليا في شبكة البيانات. 


ال الخانة الحالية :CurrentCel]‏ 
تعيد خانة شبكة البيانات 1736301100011 المحددة حاليا. 


العنصر 0ه)1: 
تقرأ أو تغير قيمة خانة معينة في جدول العرض.. ولهذه الخاصية صيغتان: 
-١‏ الأولى تستقبل كائن الخانة 17213001100611 التي تريد التعامل معها. 
١‏ - الثانية تستقبل رقم الصف ورقم العمود اللذين توجد فيهما الخانة. 


7 فون أول عمود مرئي :FirstVisibleColumn‏ 


57 يور عدد الأعمدة المرئية :VisibleColumnCount‏ 
تعيد عدد الأعمدة الظاهرة حاليا على الشاشة. 


7 فينم عدد الصفوف المرئية :Visible RowCount‏ 
تعيد عدد الصفوف الظاهرة حاليا على الشاشة. 


وخ العرض المسطح :F۴1a)M 0de‏ 
إذا حعلك قد هذه الخاصية ووه فيتقظين قك يانات انكل س 
والقيمة الافتراضية لهذه الخاصية هي عءإه۴. 


]ا الصفوف الرئيسية مرئية e[ط0wsVisi‌Paren)R:‏ 
إذا جعلت قيمة هذه الخاصية 116 (وهي القيمة الافتراضية)» فسيظهر 
الصف الرئيسى أعلى شبكة العرض عند عرض الصفوف الفرعية. 
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ونج لون خلفية الصفوف الرئيسية :ParentRowsBackColor‏ 
تقرأ أو تغير لون خلفية الصف الرئيسي. 


و لون نص الصفوف الرئيسية :ParentRowsForeColor‏ 
تقرأ أو تغير لون نص الصف الرئيسي. 


و- طراز لافتة الصفوف الرئيسية :ParentRowsLabe1Sty]e‏ 
تتحكم في عنوان لافتة الصف الرئيسي» وهي تأخذ إحدى قيم المرقم 
Grid ParentRowsLabelStyle‏ التالية: 


None‏ لا تعرض اللافتة أي عنوان. 
eNameا ]ab‏ تعرض اللافتة اسم الجدول. 
umnNameاد‏ تعرض اللافتة اسم العمود الرئيسي (المفتاح الأساسي). 
Both‏ تعرض اللافتة اسم الجدول واسم العمود الرئيسي 








ا عناوين الأعمدة مرئية ColumnHeadersVisib]e‏ 

أ عناوين الصفوف مرئية RowHeadersVisible‏ 

“ا العرض المفضل للعمود Preferred Column Width‏ 

5 الارتفاع المفصل للصفوف Preferred RowFIeight‏ 
عرض عناوين الصفوف RowHeader Width‏ 

3 للقراءة فقط ReadOnly‏ 

و السماح بالترتيب AlIlowSorting‏ 

"و لون الخلفية BackColor‏ 

3 لون الخلفية المتبدل Alternating BackColor‏ 

لون النص ۴٣٣۵٥1٥۲‏ 

5 لون خلفية التحديد Selection BackColor‏ 

لون نص التحديد SelectionForeColor‏ 

لون خطوط الشبكة Grid LineColor‏ 

طراز خطوط الشبكة y1eغeS Grid Li‏ 

5 لون خلفية العناوين HeaderBackColor‏ 

HeaderForeColor لون نصوص العناوين‎ iF 
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3 خط العناوين HeaderFont‏ 

لون الروابط LinkColor‏ 

ال لون التحليق فوق الروابط Link HoverColor‏ 

كما تلاحظ فإن هذه الخصائص موجودة بنفس الاسم والوظيفة في كائن طراز 
الجدول 1(3:20110136165/16» لهذا لن نعيد شرحها هنا.. عليك فقط أن تعرف 
أن خصائص طراز الجدول يكون لها الأولوية على خصائص شبكة البيانات» ولا 
تؤثر هذه الأخيرة إلا على الجدول الذي تعرضه بدون إنشاء طراز جدول خاص 
له 


كنا تمك شيكة امرض الو ساكل الكالية: 


ا إسدال :Expand‏ 

أرسل إلى هذه الوسيلة رقم الصف الذي تريد إسدال العلاقة التابعة له 

(كأنك ضغطت العلامة + المجاورة له).. فإذا لم تكن للصف المطلوب 

صفوف فرعية» فلن يحدث أي خطأء ولن تفعل هذه الوسيلة شيئا. 

ويمكنك إرسال الرقم -١‏ كمعامل لإسدال علاقات كل الصفوف: 
DataGrid1.Expand(1)‏ 

وستجد زرا اسمه 0:وم:8 في المشروع ›DataGridNavigation‏ وعند 

الضغط عليه ميتم إسدال كل جداول مجموعة البياناث» أو إسدال اسم العلاقة 

لكل صف من صفوف جدول المؤلفين» كما في الصورة. 

1107 مء فستختفي العلامة + من جوار كل صف» لكن ضغط 

الزر 0موم:8 سيظل يسدل اسم العلاقة لكل صف» لكنها ستكون عاطلة عن 

العمل وان يؤدق ضغطها إلى ركن الصنارف الد 


Î Form1 
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7# هل هو مسدل :IsExpanded‏ 
تعيد 116 إذا كانت علاقة الصف الذي أرسلت إليها رقمه مسدلة.. لاحظ أن 
خطأ سيحدث إذا أرسلت إلى هذه الوسيلة الرقم .٠-‏ 


#أ> طي عوم60112©: 

أرسل إلى هذه الوسيلة رقم الصف الذي تريد طي العلاقة التابعة له 
(كأنك ضغطت العلامة - المجاورة له).. فإذا لم تكن للصف المطلوب صفوف 
فرعية» فلن يحدث أي خطأء ولن تفعل هذه الوسيلة شيئا. 
ويمكنك إرسال الرقم -١‏ كمعامل لطي كل علاقات الصفوف: 

DataGrid1.Collapse (-1)‏ 
وستجد زرا اسمه 6وم00112 في المشروع ›DataGridNavigation‏ عند 
الضغط عليه يتم طي كل جداول مجموعة البيانات» أو طي اسم العلاقة لكل 
صف من صفوف جدول المؤلفين. 


17> معرفة حدود الخانة 111302065 6)6©: 
تعيد كائن المستطيل عاع:ج]ع26 الذي يمثل موضع وأبعاد الخانة المرسلة 
كمعامل.. ولهذه الوسيلة صيغتان: 
-١‏ الأولى تستقبل كائن الخانة 1238]801100:[11. 
"- والثانية تستقبل رقم الصف ورقم العمود اللذين توجد فيهما الخانة. 


7# معرفة حدود الخانة الحالية 611162601115005 6: 
تعيد كائن المستطيل Rectangle‏ الذي يمثل موضع وأبعاد الخانة المحددة 
حاليا في شبكة البيانات. 


7# هل هو محدد 0ع]ء195616: 
تعيد 116 إذا كان الصف الذي أرسلت إليها رقمه محددا. 


7# تحديد )ع ع561: 
إضافة إلى الصيغة الموروثة من الفئة 1101© والتي تحدد شبكة البيانات 
نفسها (تنقل غليها المؤشر وuعه۴)»‏ توجد صيغة أخرى تحدد الصف الذي 
ترسل إليها رقمه كمعامل. 


2# إلغاء التحديد )ع11225616: 
تذيل تهديد الصف الذى ترسل الها كيده فيعامل:, 


(0۰ 


> تصفير التحديد :ResetSelection‏ 





تزيل تحديد كل صفوف شبعة البيانات. 


الانتقال إلى الخلف :Navigate Back‏ 

تعرض الجدول الرئيسي الذي كان معروضا قبل الجدول الحالي في شبكة 
البيانات., فمثلا: لى كانت كتب توفيق الحكيم معروضة حالياء فستعيد هذه 
الوسيلة عرض جدول المؤلفين.. أما إذا لم يكن هناك جدول سابق» فلن يحدث 
خطأ في البرنامج» ولن تفعل هذه الوسيلة شيئا.. هذا معناه أنها تؤدي نفس 
وظيفة زر التراجع الموجود أعلى شبكة البيانات.. ويمكنك تجربة هذه الوسيلة 
بضغط الزر Navigate 8a)‏ في المشروع .DataGridNavigation‏ 


الانتقال إلى :NavigateT0‏ 

أرسل إلى هذه الوسيلة رقم الصف» واسم العلاقة» لعرض سجلاته الفرعية في 
شبكة البيانات» تماما كأن المستخدم ضغط العلاقة الخاصة بهذا الصف.. ولا 
تسبب هذه الوسيلة أي خطأ في البرنامج إذا لم يكن الصف المطلوب مرتبطا 
بالعلاقة المذكورة» ولكنها بدلا من هذا تقوم بالعودة إلى الجدول الرئيسي 
مجدداء كأنك استدعيت الوسيلة ع[71391216120.. ويمكنك تجربة هذه 
الوسيلة بضغط الزر NavigateTo‏ في المشر وع .DataGridNavigation‏ 


تغيير ربط البيانات :SetData Binding‏ 

تربط شبكة العرض بمصدر البيانات» وهي تستقبل معاملين: 
- الكائن الذي يعمل كمصدر للبيانات 5011106 02128آ. 
- اسم الجدول أو المجموعة التي تعمل كعنصر للبيانات. 

اختبار الضغط )وع'111)1: 

تعيد كائن معلومات اختبار الضغط Hestin‏ الذي يحوي معلومات عن 
النقطة المرسلة كمعامل إلى هذه الخاصيةء سواء كانت في صورة كائن نقطة 
؛تذ20 أو في صورة الإحداثيين الأفقي × والرأسي ۷. 
والفئة 21116561010 معرفة داخل الفئة 1(3420130»: وهي تمتلك الخصائص 
التالية: 

9 لق | Nowhere‏ | تعيد كائن معلومات اختبار «HitT'estInfo‏ 
يشير إلى نقطة موجودة في منطقة فارغة من 
جدول العبركن (لسخ ها كانات عانية 
أو خانات عناوين). 

9 بور | مدمن1ه0) | تعيد رقم العمود الذي توجد فيه نقطة الاختبار. 
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Row 1-E 
Type E 











تعيد رقم الصف الذي توجد فيه نقطة الاختبار. 

تع ائ قيم الر قم 

10 التي تخبرك 

بنوع المنطقة التي توجد بها نقطة الاختبار.. 

وهذه القيم هي: 

- عمده[<: منطقة فارغة. 

- 1اءع'): خانة. 

- 1163061ن[00: رأس عمود. 

:RowHeader -‏ رأس صف. 

- ieئumnReاC:‏ الخط الرأسي الفاصل 
بين رأسي عمودين. 

- 126و120126: الخط الأفقي الفاصل بين 
رأسي صفين. 

- 0م03: شريط العنوان العلوي لشبكة 
البيانات. 

:ParentR ows -‏ الص فوف الرئيسية 
المعروضة أعلى شبكة البيانات. 


كما تمتلك شبكة البيانات الأحدات التالية: 


# الخانة الحالية تغير ت :CurrentCellChanged‏ 
ينطلق عندما تتغير الخانة المحددة حاليا في شبكة البيانات. 


7 ضغط زر الرجوع :BackButton Click‏ 
ينطلق عندما يضغط المستخدم زر الرجوع إلى الخلف الموجود أعلى شبكة 


البيانات. 


:Navigate تصفح‎ 2# 


ينطلق عندما تنتقل شبكة البيانات لعرض جدول آخر. . والمعامل الثاني ع لهذا 
الحدث من النوع sع ve۲4‏ ٤مNavigat›‏ وهو يمتلك الخاصية 101310 
التي تعيد 16 إذا كان الانتقال إلى الأمام (إلى جدول فرعي). 


#2 ضغط زر عرض تفاصيل السجل الرئيسي 5110751221:1101(616211513116601100110[2: 














ينطلق عندما يضغط المستخدم زر عرض أو إخفاء تفاصيل السجل الرئيسي» 
المعروض أعلى شبكة البيانات. 


۶ انزلاق :٥۵11‏ 
ينطلق عندما يتحرك أحد المنزلقين الأفقي أو الرأسي في شبكة البيانات. 


والآن» لعلك لاحظت مدى تواضع الأداة 0 بالنسبة إلى الأداة 
7177 ووإن كانت الأولى ما تزال صالحة للاستخدام في الحالات التي 
تريد فيها عرض بعض البيانات دون الحاجة إلى التحكم الكامل في الأعمدة 
والصفوف ومحتويات الخانات» فكما ترىء لا تقدم لك شبكة البيانات أية طريقة 
للتعامل مع الصفوف والأعمدة والخانات؛ إلا بمعرفة أرقامهاء أو بتغيير طراز 
عرض الأعمدة» وهو ما يحد من قدرتك على برمجة هذه الأداة بشكل كبيرء ولعله 
السبب الرئيسي الذي حدا ميكروسوفت إلى إنشاء جدول العرض! 


- ١ ۷ 
مُكرر البيانات‎ 
Data Repeater 


تمنحك هذه الأداة القدرة على عرض البيانات في صورة قائمة 1.156 من العناصر 
بالتنسيق الذي تريده.. وتختلف هذه الأداة عن القوائم التقليدية في أنها لا تعرض 
العنصر على شكل نص أو صورة» بل تتيح لك تصميم كل عنصر بأي عدد من 
الادوات كما تريد» وباي شكل تریدء كما تبين الصورة التالية: 


1 




















لو تأملت الصورة السابقة» فسيتضح لك أن القائمة التي نتحدث عنها تعرض 
سجلات جدول المؤلفين» حيث يتم عرض كل مؤلف في ٥‏ مربعات نصوص مع 
وجود اللافتات اللازمة التي تشرح وظيفة كل مربع نص.. هذا معناه أننا استخدمنا 
1۰ أدوات لتصميم طريقة عرض كل عنصر في القائمة. 
کے هل تكن بتطبطر ون إلى تصبميم كل العحاصن ا دا 
بالطبع ل وإلا كان الأمر مستحيلا. . في الحقيقة نحن نصمم عنصرا واحدا فقط في 
القائمة» ومن ثم يعمل هذا العنصر كقالب 011 تنسخ باقي العناصر منه.. 
لهذا تسمى هذه الأداة بمكرر البيانات «DataRepeater‏ وهي ترث الففة 
»0ntainerContrَ01‏ لهذا فهي تعمل كأداة حاوية.. هذا هو ما يتيح لنا وضع 
أدوات أخرى عليها لتصميم عناصر القائمة. 
دعنا ونرى كيف نستخدم هذه الأداة لعرض بيانات المؤلفين: 
- افتح مشرو عا جديدا اسمه Repeater‏ (ستجده ضمن مشاريع هذا الكتاب). 
- أضف مصدر بيانات إلى المشروع يحتوي على الجداول Authors‏ 
و Books‏ و .Countries‏ 
- افتح مخطط مجموعة البيانات» وأضف إلى جدول المؤلفين عمودا جديدا 
ادسمه 0011177): وضع في الخاصية 101وو16م183 النص: 
arent. Name‏ لتجعل هذا العمود يعرض أسماء الدول التي ينتمي إليها 
المؤلفون» بدلا من أن نعرض للمستخدم أرقام الدول. 
- انتقل إلى النموذج» وافتح صندوق الأدوات» وأسدل عناصر الشريط 
›Visua1 Basic PowerPacks‏ واسحب الأداة Data Repeater‏ وأسقطها 
على النموذج. . : 
- استخدم مقابض الأداة لمنحها الشكل الملائم.. ولو أردت تغيير موضع الأداة 
فعليك سحبها من علامة الأسهم الموجودة على الركن العلوي الأيسرء وهي 
لا تظهر إلا إذا ضغطت إطار الأداة بالفأرة» تماما كما تفعل مع أي أداة 
حاوية. 


o create Data Repeater items, drag items from the Data 
Sources window or the Toolbox onto this design surface, 





- كما تلاحظ في الصورة» ينقسم سطح الأداة إلى جزئين: 
-١‏ قالب العنصر :Item Template‏ 


“oo 





وهو الجزء العلوي» الذي يوجد سهم أسود على يساره.. ولو ضغطت 
هذا الجزء فسيتم تحديد إطاره وسيمكنك تغيير حجمه باستخدام 
المقابض.. ويمكنك وضع الأدوات من صندوق الأدوات في هذا الجزءء 
كما يمكن ك سحب العناصر مسن نافذة مصادر البيانات 
(ata 5‏ وإلقائها عليه مباشرة لإنتاج أدوات مرتبطة بالبيانات.. 
لاحظ أن مكرر البيانات يشترط وجود أداة واحدة على الأقل مرتبطة 
بالبيانات» وغير هذاء تستطيع وضع أية أدوات أخرى تريدهاء كمربع 
صورة يعرض صور رمزية. أو زرا ينفذ وظيفة معينة» أو لافقات 
تشرح وظائف مربعات النصوص.. ويقوم مكرر البيانات بعمل نسخ من 
هذا القالب» لعرض كل عنصر في مصدر البيانات. 
؟- حاوية العرض :View p0)‏ 
هذا هو الجزء السفلي الفارغ من الأداةء وعند ضغطه يتم تحديد الأداة 
كلها.. ولا تستطيع إضافة أية أدوات إلى هذا الجزءء ووظيفته الوحيدة 
هي تحديد مساحة عرض الأداة على النموذج.. لهذا يمكنك سحب حواف 
صغر مساحة مكرر البيانات» فهو يعرض منزلقا رأسيا إذا احتاج إلى 
ذلك» ليستطيع المستخدم عرض العناصر غير الظاهرة.. والأفضل أن 
تستخدم الخاصية 4101 من نافذة الخصائص لتثبيت حواف الأداة 
بالنسبة لحواف النموذج» بحيث يتم تكبير أو تصغير مكرر البيانات إذا تم 
تكبير أو تصغير النموذج. 
- افتح نافذة مصادر البيانات 51/120016 Sources‏ 10348 واضغط زر إسدال 
طريقة العرض المجاور للعنصر 11015 واختر 1268115 من القائمة 
المنسدلة.. واجعل الحقل 001117 يعرض بياناته في قائمة مركبة 
0x‏ 08ط€0m»‏ ثم اسحب جدول المؤلفين وألقِه على قالب العنصر في 
مكرر البيانات.. سيؤدي هذا إلى إضافة الأدوات المناسبة إلى مكرر البيانات 
والنموذج.. احذف مربع النص واللافتة المرتبطتين بالحقل 150ر uهC»ء‏ 
ونسق شكل الأدوات كما تريد. 
ع" أف وبر اال قالب العتصين» استكفيه ر کن كني الولف 
لاحظ أن مكرر البيانات يسبب مشاكل إذا حاولت تصمم عنصر يعرض بيانات 
مترابطة.. مثلا: لو عرضت كتب المؤلف الحالي في جدول عرضء فسيعرض 
جدول العرض كتب أول مؤلف في سجلات باقي المؤلفين!!.. وهو نفس ما سيحدث 
لو حاولت عرض الكتب في قائمة أو قائمة مركبة!!.. بل إنك لو غيرت العنصر 
المحدد في القائمة المركبة في أحد السجلات» فسيتم تغييره في كل القوائم المركبة 
الموجودة في باقي السجلات!!.. بينما لو كانت القائمة المركبة تعرض عناصر 
عادية (مضافة إلى المجموعة 5:مه:1 دون الارتباط بمصدر بيانات)» فستعمل كل 


نسخة من القائمة بشكل مسقل وصحيح!.. لهذا علينا أن نكتب بعضن الكود لتملا 
قائمة الدول.. أضف هذا الكود إلى حدث تحميل النموذج: 
For Each R As BooksDataSet.CountriesRow In‏ 
BooksDataSet.Countries.ROows‏ 
CountryComboBox.Items.Add(R.Name)‏ 
Next‏ 


لاحظ أنك لو أضفت هذا الكود بعد ملء جدول المؤلفين بالبيانات» فلن تعرض 
ا وحم أن لاضن موجرية ي 


البيانات منه CG ES‏ هذا 
معناه أنه أنشأ نسخا من القائمة المركبة الفارغة من العناصر وعرضها.. لهذا لا 
يفيدك ملء القائمة الأصلية بعد هذاء فهي ليست مرتبطة فعليا بالنسخ المعروضة 
للمستخدم.. هي فقط مجرد قالب عاهام ص1 يتم ا . لهذا يجب أن تملا 
هذا القالب بالبيانات أولا وتضبط خصائص شكله ولون خطه وطريقة عرضه» قبل 
أن يتم عمل نسخ منه.. هذا معناه أن أفضل مكان لوضع الكود السابق هو بعد جملة 
ملء جدول الدول وقبل جملة ملء جدول المؤلفين! 

وهناك حححكلن اخصجيرن لهذه المشكلة هو استخدام الوسمييلتين 
BeginResetItemTemplate‏ و EndResettem Template‏ كما سنرى لاحقا. 

ولا تنس أن تستخدم نافذة الخصائص لتجعل قائمة الدول تعمل كقائمة منسدلةء 
وذلك بوضع القيمة 100100101156 في الخاصية ..DropDownSty|e‏ هذا 
سيمنع المستخدم من الكتابة في مربع نص القائمة المركبة» حتى لا يكتب اسم دولة 
خاطئ» وبدلا من هذا سيختار الدولة التي يريدها من القائمة.. لاحظ أن الخاصية 
۲٠×)‏ الخاصة بالقائمة المركبة مرتبطة بالحقل /411101.00011201, بسبب سحبها 
من نافذة مصادر البيانات.. سنترك هذا كما هوء ولن يحدث خطأء فعندما يوضع في 
الخاصية )×1 نص موجود فعلا في القائمة» فإن القائمة تحدد هذا العنصرء وهو 
ما سيجعل البرنامج يعمل بشكل صحيح. 

أما إذا أردت عرض كتب كل مؤلف» فأفضل حل هو استخدام زر يؤدي ضغطه 
إلى عرض نموذج جديد عليه كتب المؤلف الحالي.. وعموما هذه هي الطريقة 
الأكفأء فليس من الذكى عرض كما ضخما من البيانات فى مكرر البيانات» لأنها 
ستلتهم مساحة عرض كبيرة وتستهلك مساحة كبيرة في الذاكرة! 

لو شغلت البرنامج الآن» فسيعرض بيانات كل مؤلفين في أدوات العرض التي 
صممناها.. وسنرى ونحن نتعرف على خصائص ووسائل مكرر البيانات كيف 
نكمل وظائف هذا البرنامج. 


DataRepeater Class فئة مكرر_البيانات‎ 2 


هذه الفئة موجودة في النطاق »MicrosoÊft. VisualBasic.PowerPacks‏ وهي 
ترث الفئة .ContainerContro]‏ 
وإضافة إلى ما ترثه من الفئة الأم» تمتلك هذه الأداة الخصائص التالية: 


"لآ السماح للمستخدم بإضافة عناصر ومرع0014 411019175617104 : 
إذا جعلت قيمتها 1:16" (وهي القيمة الافتراضية)» فسيتمكن المستخدم من 
إضافة سجل جديد إلى مكرر البيانات» وذلك بضغط زر الإضافة الموجود 
على شريط موجه الربط أو بتحديد أي سجل في مكرر البيانات 
(بضغط الهامش الأيسر للسجل» حيث سيظهر فيه سهم يدل على أنه محدد)؛ 
وضغط 0K1۸ ]+×N‏ من لوحة المفاتيح. 
ويعرض السجل الجديد القيم الافتراضية للحقولء وإذا لم تكن للحقل قيمة 
افتراضيةء فستعرض الأدوات قيم أول أو آخر سجل في الجدول.. طبعا هذا 
غير مرغوب» وعليك التأكد من إفراغ الحقول من هذه القيم» كما سنرى 
لاحقا.. لاحظ أن السجل الجديد يتم حذفه إذا غادره المستخدم دون أن يكتب 
فيه أية بيانات. 
أما إذا جعلت قيمة هذه الخاصية 12156؛ فلن يمكن للمستخدم إضافة سجل 
جديد بضغط [3+,01181) من لوحة المفاتيح» لكن سيظل زر إضافة سجل 
جديد الموجود على موجه الربط فعالاء وسيكون عليك تعطيله بنفسك. 


وخ السماح للمستخدم بحذف العناصر :AllowUser10oDeleteItems‏ 
إذا حعلت فا مز زهي القيمة الافتر اصدية)» فشكن الس تخد من 
حف النيجل التحدد خالا في مكرن اليناثك»يضبغط زر الحدق الموجود 
على شريط موجه الربط» أو ضغط الزر (٤1٤۲۴‏ من لوحة المفاتيح. 


عدد العناصر :Item Count‏ 
تعيد عدد السجلات المعروضة حاليا في مكرر البيانات. 
ويمكنك أن تضع في هذه الخاصية عدد العناصر التي تريد عرضها عند 
استخدام مكرر البيانات في الوضع الافتراضي 721006 77120131 كما سنرى 
لاحقا.. لكن محاولة وضع أي قيمة في هذه الخاصية في الوضع العادي 
ستؤدي إلى حدوث خطأ في البرنامج. 


و- قالب العنصر a)eاmp :Item Te‏ 


تعيد كائنا من النوع 11]6671ع1(3131560621» يمثل العنصر المستخدم كقالب 
في مكرر البيانات.. وسنتعرف على الفئة 122421166211117 بعد قليل. 
ويمكنك استخدام هذه الخاصية لتغيير خصائص عناصر مكرر البيانات.. 
لاحظ أنك تستطيع فعل هذا في وقت التصميم؛ وذلك بضغط قالب العنصر 
بالفأرة لتحديده» ثم ضغط 14 لعرض خصائصه في نافذة الخصائص.. هذا 
يتيح لك تغيير الخط ولون الخلفية والعديد من الخصائص الأخرى التي تؤثر 
على المساحة التي تعرض السجلات في مكرر البيانات.. بينما لو ضغطت 
جزء العرض 771670016 فستظهر خصائص مكرر البيانات نفسه في نافذة 
التصاتضن. 


3 العنصر الحالي :CurrentItem‏ 
تعيد كائنا من النو ع «DataRepeaterltem‏ يمثل العنصر المحدد حاليا في 
مكرر البيانات.. ويمكنك أيضا أن تضع في هذه الخاصيةء كائن العنصر الذي 
تريد تحديده.. ولا توجد طريقة اتحديد أكثر من عنصر في نفس الوقت. 
لاحظ أن مكرر البيانات لا يمتلك الخاصية الافتراضية 1]6505.. السبب في 
هذا أن مكرر البيانات هو أداة حاويةء لهذا تستطيع أن تتعامل مع عناصره من 
خلال الخاصية الموروثة 011015©» التي تستطيع أن ترسل إليها رقم 
العنصر لتعيد إليك الكائن الذي يمثله.. مثال: 
Dim Itm As DataRepeaterItem = DataRepeater1.Controls(0)‏ 
والمثال التالي يتيح لك المرور عبر عناصر مكرر البيانات: 
For Each Itm As DataRepeaterIltem In‏ 
DataRepeater1.Controls‏ 
Msgbox(Itm.ItemIndex)‏ 
Next‏ 
ولا تنس استخدام جملة التضمين التالية أعلى صفحة الكود قبل تجربة المثال: 
Imports Microsoft. VisualBasic.PowerPacks‏ 
لكني لا أنصحك باستخدام هذه الطريقة» لأنها ستمر على بعض عناصر مكرر 
البيانات فقط وبترتيب عشوائي!!. . السبب في هذا أن مكرر البيانات يعرض 
فقط العناصر الظاهرة للمستخدم على الشاشة ولا يعرض باقي العناصر إلا 
إذا حرك المستخدم المنزلق الرأسي.. لذا إذا أردت إجراء أي تغيير على 
العناصرء فاستخدم الحدث رورعغ11ج1(1 لفعل هذاء فهو ينطلق قبل عرض كل 
عنصر. 


وخ رقم العنصر الحالي :CurrentItemIndex‏ 


تعيد رقم السجل المحدد حاليا في مكرر البيانات. . ويمكنك إرسال رقم أي 
سحلا ليتم تحديده.. والمثال التالي يحدد السجل الثاني في الأداة: 
DataRepeater1.CurrentItemIndex = 1‏ 


وخا عدد العناصر المعروضة :DisplayedIte Count‏ 
تعيد عدد السجلات الظاهرة للمستخدم حاليا في مكرر البيانات بدون تحريك 
المنزلق الرأسي.. ولهذه الخاصية معامل منطقيء إذا جعلته 106 فسيدخل 
ضمن الحساب السجلات التي تظهر أجزاء منها فقط: 
MsgBox(DataRepeater1.DisplayedItemCount(True))‏ 
أما إن جعلته ع015'[» فسيتم حساب عدد السجلات الظاهرة بصورة كاملة: 


MsgBox(DataRepeater1.DisplayedItemCount(False)) 


ف رقم أول عنصر معروض :FirstDisplayedItemIndex‏ 
تعيد رقم أو سجل ظاهر للمستخدم في مكرر البيانات. 


وغ رأس العنصر مرئي :Item Header Visible‏ 
إذا جعلت قيمتها 12156؛ فسيتم إخفاء الهاش الأيسر الذي يعرض رءوس 
العناصر.. والقيمة الافتراضية ©1111 . 


وخا حجم رأس العنصر :ItemHeaderSize‏ 
تقرأ أو تغير عرض الهامش الايسر الذي يعرض رءوس العناصر. 


ونج لون التحديد :SelectionColor‏ 
تقرأ أو تغير لون الخلفية الذي يعرض في خانة رأس السجل المحدد حاليا. 


وخ طراز المخطط ع1:29011]511: 
تفرأ أو تغير طريقة عرض مكرر البيانات» وهي تأخذ إحدى قيمتي المرقم 
1م التاليتين: 


1 | يتم تكرار العناصر رأسيا (من أعلى إلى أسفل) في شكل 
صفوف.. هذا هو الوضع الافتراضي. 

Horizontal‏ | يتم کر العناصر أفقيا (من اليسار إلى اليمين) في شكل 
أعمدة ويظهر هامش علوي يحمل ر ءوس هذه الأعمدة.. 
ويمكنك رؤية هذا في المشروع .RepeaterItemColor‏ 
وتمتلك هذه الأداة الوسائل التالية: 
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ف 


ب 


ف 


إضافة جديد 00771 4: 
تضيف سجلا إلى نهاية مكرر البيانات.. وتسبب هذه الوسيلة خطأ إذا كانت 
للخاصية وررورع]001ه0 41107175611 القيمة False‏ . 


حذف من موضع )1211014: 
أرسل إلى هذه الوسيلة رقم السجل الذي تريد حذفه من مكرر البيانات. 


إلغاء التحرير :CancelEdit‏ 
تلغني البيانات التي أدخلها المستخدم في السجل الحالي» وتعية.وظيع القيم 
الأصلية في الأدوات.. هذا مفيد إذا أردت أن تمنح المستخدم القدرة على 
ضغط الزر 6 من لوحة المفاتيح لإلغاء التغييرات التي أجراها في السجل 
الحالي. .قي هذه الحالة عليك أن تكتب إجراء يستجيب للحدث KeyDown‏ 
لجميع الأدوات التي تعرض بيانات السجل» وتكب فيه الكود الذي يستدعي 
هذه الوسيلة إن كان الزر المضغوط هو الزر ع89.. وستجد الكود التالي في 
الإجراء 119610326151701 في المشروع إع†مومه۸R»‏ مع ملاحظة أن هذا 
الإجراء يستجيب للحدث 12971201 لكل مربعات النص والقائمة المركبة 
أيضا: 

If e.KeyCode = Keys.Escape Then 

DataRepeater1.CancelEdit( ) 
End If 

لاحظ أن التغييرات التي يدخلها المستخدم في أي أداة في السجل الحالي» يتم 
قبولها بمجرد مغادرة الأداة إلى أية أداة أخرى» فى نفس السجل أو فى سجل 
آخر.. هذا معناه أن ضغط الزر :880 سيلغى التغبييرات التى حدثث فى الأداة 
الحالية فقط ولن يؤثر على أية أداة أخرى.. ولو غادر المستخدم الأداة التي 
أجرى فيها التغييرات» ثم عاد إليها وضغط 850 فلن يحدث شيء! 


تحريك العنصر إلى مجال الرؤية :ScrolIItemIntoView‏ 

أرسل إلى هذه الوسيلة رقم السجل الذي تريد تحريك المنزلق إليه ليصير 
وتوجد صيغة أخرىء تستقبل معاملا ثانياء إذا جعلته 106» فسيتم تحريك 
المنزلق بحيث يصير السجل هو أول سجل معروض في مكرر البيانات» مع 
مخاذاة الحاقة العارية لاحل بالحافة الغلوية لمكرر اسنات 


بدء تغيير قالب العنصر :BeginResetIte Template‏ 


كما أشرنا من قبل: ا دوين تجريه حاى خقائض الانوات الذاخلة في أكرين 
أردت تغيير کا أية أداقء أو أردت ۹ تعديلات على القالب نفسه 
بإضافة أو حذف أدوات من خلال الخاصية 194م7اء71مء1» فعليك أولا أن 
تستدعي الوسيلة 61701266 1271ء]]]ء1:65مزعه8 لتنبيه مكرر البيانات إلى 
أن هناك تغييرات ستحدث في طريقة العرض 


#ة> إنهاء تغيير قالب العنصر :EndResetItem Template‏ 

استدع هذه الوسيلة في نهاية الكود الذي يجري تعديلات في قالب العنصرء 
لإجبار مكرر البيانات على إنعاش العناصر التي يعرضها لتظهر عليها 
التغييرات التي حدثت.. والكود التالي يغير لون خلفية القائمة إلى الأصفرء 

ويمكنك تجربته بضغط الزر "تغير لون الخلفية" في المشروع 2161عم11: 
DataRepeater1.BeginResetltemTemplate( (‏ 
CountryComboBox.BackColor = Color. Yellow‏ 
DataRepeater1.EndResetItemTemplate( )‏ 
جرب وضع علامة التعليق ' أمام السطرين الأول والأخير في الكود السابق 

واضغط الزر.. ستجد أن لون القائمة لن يتغير. 


كما تمتلك هذه الفئة الأحداث التالية: 


تغير ر قم العنصر الحالي :CurrentItemIndexChanged‏ 
ينطلق عندما تتغير قيمة الخاصية ×عل,آصع) Cure]‏ من الكودء أو بسبب 
انتقال اام من سجل إلى آخر في مكرر البيانات. 


#7 خÎþ‏ البيانات :DataError‏ 
ينطلق عند حدوث خطأ في قراءة البيانات من مصدر البيانات» أو في نقل 
البيانات المحدثة من مكرر البيانات إليه.. والمعامل الثاني ع لهذا الحدث من 

النوع Data RepeaterDataErrorEventArgs‏ وله الخصائص التالية: 
5 هزر | ١ DataRepeater‏ تعيد عنصر مكر البيانات 
Item‏ 101 الذي يمثل السجل 
الذي حدث فيه الخطأ. 

2 بير Control‏ تعيد الأداة التي حدث فيها الخطأا. 

Name | 8 75‏ yاامpداP‏ | تعيد اسم خاصية الأداة» التي سببت الخطا.. 
بمعنى آخر: تعيد عنصر العرض. 

لور Exception‏ | تعید كائن الاستثناء 0م7206 الذي يحمل 
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معلومات الخطأ. 

ك8 | hrow Exception‏ | إذا جعلت قيمة هذه الخاصية 116» 
فسيحدث الخطأ في البرنامج بعد انتهاء هذا 
الحدث.. والقيمة الافتراضية هي .False‏ 














۶ أضاف المستخدم عناصر ودمرء15624006016]: 
ينطلق بعد أن يضغط المستخدم 1+١‏ 1۸)» وقبل أن يضاف العنصر الجديد 
الى رر النيافبات . والمحافل اللاي م لهذا الحنيك مين الفوغ 
›Data@Repeater 11071117‏ وله الخاصيتان التاليتان: 


فط | هلس [آدمع :1 | تعيد رقم العنصر الجديد. 
emu | 55“‏ | تعيد عدد العناصر التي تمت إضافتها. 














ويعتبر هذا الحدث أنسب مكان لإفراغ خانات السجل من أية قيم غير 
مرغوبة»؛ فكما ذكرنا سابقا» يعرض مكرر البيانات قيم السجل الأول أو الأخير 
في السجل الجديدء لهذا يمكنك أن تمحوهاء أو تضع بدلا منها القيم الابتدائية 
المناسبة.. وقد استخدمنا هذا الحدث لفعل هذا في المشروعين 1ع21عم116 و 
.RepeaterltemColor‏ 


2# يجري حذف عناصر ۶ہع ٤آعہDe1e)1:‏ 
ينطلق عند حذف سجل من مكرر البيانات» سواء من الكود أو بواسطة 
الس تخد والفعايسل اتان و لا الموة من التصسوع 
‘DataRepeaterAddRemoveltemsCancelEventArgs‏ وهو مماثل 
لمعامل الحدث السابقء إلا أنه يزيد عنه بامتلاك الخاصية 1[عع2ة")» وإذا 
وضعت فيها 15016 يتم إلغاء حذف السجل.. لهذا يعتبر هذا الحدث ملائما 
لتعرض رسالة للمستخدم ليؤكد رغبته في حذف السجل: 
,"هل تريد حذف هذا السجل فعلا؟")<:7155130 1f‏ 
MsgBoxStyle.OkCancel) = MsgBoxResult.Cancel Then‏ 
e.Cancel = True‏ 
End If‏ 
لاحظ أنك ضغط زر الحذف الموجود على شريط موجه الربط سيحذف 
العنصر من مصدر البيانات مباشرة» ولن تظهر رسالة التحذير.. لو أردت 
تغيير هذا الأداي فضع في الخاصية روروع)1[ع1(61»1 الخاصة بموجه الربط 
القيمة «Nothing‏ واكتب ما يلي في حدث ضغط زر الحذف: 


Dim I = DataRepeater1.CurrentItem.ItemIndex 


1T 




















DataRepeater1.RemoveAt(l) 
وستجد هذا الكود في المشروع 2161عم116].‎ 


# المستخدم يحذف عناصر :UserDeleting1tems‏ 
مماثل للحدث السابق في كل شيء»ء ما عدا أنه ينطلق فقط عندما بضغط 
المستخدم الزر 121646 لحذف السجل المحدد في مكرر البيانات» ولا ينطلق 
بسبب حذف السجل من الكود. 


۶ المستخدم حذف عناصر ودرء1961196166016]: 
ينطلق بعد أن يحذف المستخدم سجلا من مكرر البيانات» ولا ينطلق بسبب 
حذف السجل من الكود.. والمعامل الثاني ع لهذا الحدث من النوع 
›DataRepeater Add RemoveltemsEventArgs‏ وقد سبق أن تعرفنا 
عليه.. هذا معناه أنك لا تستطيع استعادة السجل بعد حذفهء فهذا الحدث لا يملك 
الخاصية [ععم00.». 


# يجري نسخ العنصر ع دز 10 )166122: 
ينطلق قبيل عمل نسخة من قالب العنصر.. والمعامل الثاني ع لهذا الحدث من 
النوع ›DataRepeatertemCloneEventArgs‏ وهو يمتلك الخصائص 
التالية: 


هن | Source‏ تعيد عنصر مكرر البيانات DataRepeaterIt{em‏ 
Repeater1tem‏ اسلناتج من عملية النسخ.. هذا 
يتيح لك التحكم في عملية النسخ كما تريدء فالكائن 
الذي تضعه في هذه الخاصية يكون هو ناتج النسخ. 

| 0160م ة]] | اجعل قيمتها 16 لتمنع مكرر البيانات من أداء 
ال الخاصية ده فى هدم الدانة بحب عبت 
»S0urce‏ وتجري هذه النسخة التعديلات التي 
تريدهاء ثم تضعها في الخاصية ام عإه1. 














© تم نسخ العنصر 10260 1)0120: 
ينطلق بعد نسخ عنصر من قالب العناصر.. والمعامل الثاني ع لهذا الحدث من 
النوع ›DataRepeatertemEventArgs‏ وهو يمتلك الخاصية 
0 التي تعيد العنصر المنسوخ.. لاحظ أن هذا العنصر لم 
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يعرض بعد في مكرر البيانات» لهذا لا تحاول استخدام رقمه في أي عمليةء 
فسيكون صفرا دائما!.. كما أن الأدوات الموجودة على العنصر ما زالت 
فارغة ولم ترتبط بمصدر البيانات بعدء لهذا لا تحاول قراءة قيمها.. كل ما 
يمكنك فعله هو تغيير خصائص هذه الأدوات بالطريقة التى تناسبك» كأن تملأ 
قال مجموعة من العتاضر مكل 1 


#2 رسم عنصر «روء)1(01:2751: 
ينطلق عند رسم عنصر في مكرر البيانات.. لاحظ أن رسم العنصر يتكرر 
مرات عديدة» حيث يعاد رسم العنصر كلما ظهر في مساحة العرض مع 
حركة المنزلق. 
والمعامل الثاني م لهذا الحدث من النوع DataRepeaterIltemEventArgs‏ 
كما فى الحدث السابق. 
ويعتبر هذا الحدث أفضل حدث يمكنك استخدامه للتحكم في العناصر 
المعروضة:؛ فهو الحدث الوحيد الذي ينطلق بعد إضافة العنصر إلى مكرر 
البيانات فعلا وبعد إتمام ربط أدواته بالبيانات.. لهذا استخدمنا هذا الحدث في 
المشروع 101 126624611665100 لأداء الوظيفتين التاليتين: 
-١‏ إذا كان العنصر زوجيا نلونه بالأخضرء وإذا كان فرديا نلونه بالأصفر: 
If e.DataRepeaterItem.ItemIndex Mod 2 = 0 Then‏ 
e.DataRepeaterItem.BackColor = Color.Green‏ 
Else‏ 
e.DataRepeaterItem.BackColor = Color. Yellow‏ 
End If‏ 


شاعر عضرث حعاضصر 


عمغور في الشرقر 
بوميات ناتب في الأياف 





؟- نقرأ رقم المؤلف المعروض في مربع النص» ونستخدمه لنحصل على 
كائن عرض 1034217167 يحتوي على كتبه» ونجعله مصدر البيانات 
للقائمة لكي تعرض كتب المؤلف الحالي.. لاحظ أن هذه هي الطريقة 
الصحيحة الوحيدة لربط القائمة بمصدر البيانات» حيث يجب أن نربط 
كل نسخة من القائمة بمصدر بياناتها على حدة» وقد رأينا من قبل كيف 
تفشل محاولة ربط القائمة الموضوعة على قالب العنصر بالبيانات.. 
لكن عيب هذه الطريقة هو أنك مضطر إلى إعادة ربط القائمة بمصدر 
البيانات في كل مرة يتم فيها رسم العنصر.. ولو جربت الكود التالي» 
فسيؤدي إلى نتائج خاطئةء وستعرض بعض القوائم كتب مؤلفين 
اخرين: 
If BksLst.DataSource Is Nothing Then‏ 
BksLst.DataSource = Books View‏ 
BksLst.DisplayMember = "Book"‏ 
End If‏ 
السبب في هذا أن الشرط سيكون صحيحا مرة واحدة فقط عند رسم 
القائمة لأول مرةء لكن بعد هذا كلما تحرك المنزلق وأعيد رسم 
العنصرء فسيكون الشرط خاطئاء ولن يتم ربط القائمة بمصدر 
البيانات» مما سيجعلها تعرض نتائج خاطئة.. لست أعرف يقينا سبب 
هذا ولكني أخمن أن مصممي مكرر البيانات يحسنون أداءه بتحريك 
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القوائم من العناصر التي اختفت مع حركة المنزلق» لعرضها على 
العناصر التي ظهرت على الشاشة!.. لهذا لو لم تقم بتحديث محتويات 
كل قائمة بنفسك عند رسم العنصرء فإنها تظل تحتفظ بنتائج تخص 
سجلات اخری! 
لاحظ أن خطأ سيحدث في الكود الذي كتبناه عند رسم العنصر الجديدء لأنه 
غير مرتبط بعد بصف في مجموعة البيانات.. لهذا علينا إضافة شرط لإنهاء 
الكود إذا كان العنصر جديدا.. يمكننا أن نعرف هذا إذا كان مربع النص 
1801 يحمل رقما سالبا لأنه لم يأخذ رقما تلقائيا بعد: 
Dim AuthorID As Integer =‏ 
Itm.Controls("IDTextBox"). Text‏ 
If AuthorID < 0 Then Exit Sub‏ 
ولإكمال وظيفة البرنامج» سمحنا للمستخدم بالنقر المزدوج بالفأرة على 
القائمة» واستخدمنا الحدث ع1ح12011616)011 الخاص بها لنعرض تفاصيل كتب 
المؤلف الحالي في جدول عرض على نموذج مستقل.. في الحقيقة هذا الكود 
هو نفسةه مضدر بيانات القائمة: 
FrmBooks.GrdBooks.DataSource = BksLst.DataSource‏ 
النقطة الوحيدة الهامة هناء هي أننا لا نستخدم القائمة 2001251151 الموضوعة 
على قالب العنصرء وإنما نستخدم نسخة القائمة الخاصة بالعنصر الحالي في 
مكرر البيانات.. وسنعرف لاحقا كيف نحصل على هذه النسخة. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


استخدام مكرر البيانات في الوضع الافتراضي: 

رأينا من قبل كيف نستخدم قائمة العرض ۷1ء11 وجدول العرض 
27177 في الوضع الافتراضي.. وبالمثل يمكننا استخدام مكرر البيانات 
في الوضع الافتراضي.. هذا مفيد إذا كنت تولد البيانات بناء على معادلة دون 
الحاجة إلى مصدر بيانات» أو إذا كان حجم البيانات ضخماء وتريد التدخل في 
طريقة عرضها لتحسين أداء البرنامج. 

ويريك المشروع 171012116062461 كيف يمكن عرض بيانات المؤلفين في 
مكرر البيانات بطريقة افتراضية» مع عرض كتب كل مؤلف في جدول عرض في 
نفس السجل.. في هذه الحالة يحتفظ مكرر البيانات في الذاكرة ببيانات المؤلفين 
الظاهرين على الشاشة فقطء وكلما تحرك المستخدم بالمنزلق سيطلب منا مكرر 
البيانات إمداده ببيانات المؤلفين المراد عرضهم. 


«د >> ا 
كر 
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دعنا نتعرف على الخصائص والوسائل والأحداث التي يمنحها لنا مكرر البيانات 

للتعامل مع الوضع الافتراضي» لنرى كيف نستخدمها في كتابة هذا المشروع: 

وخ الوضع الافتراضي 7711:61121/1006: 
إذا جعلت قيمة هذه الخاصية ‘True‏ فسيعمل مكرر البيانات في الوضع 
الافتراضي.. والقيمة الابتدائية لهذه الخاصية هي ©3015 .. وقد استخدمنا نافذة 
الخصائص في المشروع VirtualRepeater‏ لجعل قيمة هذه 
الخاصة عںإآ.. ونظرا لأن الخاصية 014')رمع:1 لا تظهر في نافذة 


11۸ 








الخصائص» فقد استخدمنا حدث تحميل النموذج لنضع فيها عدد المؤلفين 
المراد عرضهم: 

DataRepeater1.ItemCount = BooksDataSet.Authors.Count 
لو شغلت المشروع الآن» فسترى عناصر بعدد المؤلفين معروضة في مكرر‎ 
البيانات.. ورغم أن هذه العناصر ستعرض الأدوات التي وضعتها على قالب‎ 
العنصر في وقت التصميم» فستكون فارغة» لأن تقنية الربط عمنلمز8 لا‎ 
تعمل في الوضع الافتراضي للأسف!!.. لهذا عليك كتابة الكود الذي يعرض‎ 
البيانات في هذه الأدوات بنفسك» كما سنرى بعد قليل.‎ 


5 قيمة العنصر مطلوبة :Item ValueNeeded‏ 
ينطلق هذا الحدث عندما تحتاج أداة موجودة في أحد السجلات إلى عرض 
فما هذا يمل اللاققات ومر يعات التصوض» ليذا عليك أن قق من 
الأداة قبل أن تضع فيها القيمة.. ويعتبر هذا الحدث المكان الملائم لعرض 
البيانات في الأدوات في الوضع الافتراضي.. والمعامل الثاني م لهذه الحدث 
من النوع »DataRepeatertem Value Even{A1gs‏ وله الخصائص التالية: 


كط | 1[006:2درع]]1 ١‏ تعيد رقم العنصر في مكرر البيانات. 

5 1منمه0© | تعيد الأداة التي تحتاج إلى عرض البيانات. 

55 | راامpداP‏ | تعيد اسم خاصية الأداة التي ستعرض البيانات 
عمتولا |(عنصر العرض). 

وبع م __ ضع في هذه الخاصية القيمة التي تريد عرضها في 
الأداة.. لاحظ أن هذه الخاصية حساسة جدا لنوع 
البيانات» لهذا عليك إجراء عمليات التحويل 
المناسبة قبل وضع القيمة فيها.. مثلا: لو وضعت 
الرقم ١‏ في هذه الخاصية لعرضه في مربع النص 
301 الذي يعرض رقم المؤلف» فلن 
يظهر في مربع النص أي شيء!.. بينما لو وضعت 
النص ٣۳‏ فن هذه الخاصية فسيظهر في مربع 
النص!.. السبب في هذا أن الخاصية ×ه1 تقبل 
نصوصا لا أعدادا صحيحة؛ والخاصية عں إ۷ .م 
لا تقوم بالتحويل المطلوب!.. لهذا عليك استخدام 
الوسيلة ع1053 لتحويل الحقول الرقمية إلى 
نصوص قبل وضعها في هذه الخاصية. 

وقد استخدمنا هذا الحدث في المشروع 171018116062161 لعرض القيم في 
الأدوات.. هذا الكود بسيط للغاية» فهو يستخدم الجملة الشرطية )ه561 
ليفحص اسم كل أداة» ويضع فيها القيمة المناسبة.. ولا تحتاج قراءة القيم من 
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جدول المؤلفين إلى كود معقدء فرقم العنصر في مكرر البيانات» هو نفسه رقم 
السجل في جدول المؤلفين.. سيكون هذا الكود على الصورة التالية: 
Dim Authors = BooksDataSet. Authors‏ 
Select Case e.Control.Name‏ 
Case "IDTextBox"‏ 
e.Value =Authors(e.ItemIndex).ID.ToString‏ 
Case "AuthorTextBox"‏ 
e.Value =Authors(e.ItemIndex). Author‏ 
End Select‏ 
ونظرا لأن بعض الحقول قد تسبب مشاكل إذا كانت فار غة ااں ط0 لذا 
عليك استخدام المقطع 0201© 1537 للاحتراز.. وستجد هذا الكود كاملا في 
المشروع VirtualRepeater‏ . 
لاحظ أن جدول العرض لا يطلق الحدث 4ءء n۷ a1]uع N‏ ءt]ء‏ لهذا عليك 
استخدام الحدث ٣آ‏ سه5 لربط جدول العرض بكتب المؤلف.. كل ما 
سنفعله» هو الحصول على كائن عرض 0601 577167 يحتوي على كتب 
المؤلف الحالي» ووضعه كمصدر بيانات لجدول العرض: 
Dim Itm = e.DataRepeaterItem‏ 
Dim Authors = BooksDataSet. Authors‏ 
الحصول على كائن عرض الصف الخاص بالمؤلف الحالي ' 
Dim Rv = Authors.DefaultView(Itm.ItemIndex)‏ 
Dim RI = BooksDataSet.Authors.ChildRelations(0)‏ 
الحصول على نسخة جدول العرض الحالية ' 
Dim GrdBooks = CType(Itm.Controls(‏ 
"BooksDataGridView'"), DataGridView)‏ 
الحصول على كائن عرض كتب المؤلف الحالي من خلال العلاقة ' 
واستخدامه كمصدر بيانات لجدول العرض ' 
GrdBooks.DataSource = Rv.CreateChildView(RI)‏ 


1V: 


۶۶ عنصر جديد مطلوب :NewItem Needed‏ 
ينظلق هذا الحدث عندما يطلب الاستخدم إطبافة بيجل جدية إلى .مكتوز 
البيانات بضغط [1+,20111.. هذا يتيح لك إضافة سجل جديد إلى مصدر 
البيانات» حتى يمكن حفظ البيانات التي يدخلها المستخدم فيه.. وقد استخدمنا 
هذا الحدث في المشروع 571012116062141 لإضافة صف جديد إلى جدول 
المؤلفين كالتالي: 
Dim R = BooksDataSet.Authors.NewAuthors Row‏ 
R.Author = " "‏ 
R.CountryID = 12‏ 
BooksDataSet.Authors.AddAuthorsRow(R)‏ 
لاحظ أننا وضعنا مسافة في حقل اسم المؤلف. لأن جدول المؤلفين لا يسمح 
بتركه فارغاء كما وضعنا الرقم 5 مبدئيا في حقل رقم الدولة لنفس السبب.. 
لو لم نفعل هذاء فسيحدث خطأ في البرنامج. ويمكنك التخلص فن السنافة قبل 
عرضها في مربع النصء» > باستخدام الوسيلة ص٣1‏ في الحدث 
.ItemValueNeeded‏ 


إضافة عنصر 16»540060: 
ينطاق هذا الحدث يعد إضافة السكل الجديد إلى مقرر البياتااة» كنك قراءة 
رقم العنصر الجديد.. والمغامل الثاني ع لهذا الحدث من النوع 
DataRepeaterAddRemoveltemsEventArgs‏ الذي تعرضا عليه 
سابقا.. لاحظ أن ترتيب استدعاء الأحداث عند إضافة عنصر جديد كالتالى: 

.NewlItemNeeded - 

.ItemValueNeeded 

.Drawltem - 

.ItemsAdded - 


۶ دفع قيمة العنصر :Item Value Pushed‏ 
ينطلق هذا الحدث عندما يغير المستخدم قيمة إحدى الأدوات الموضوعة على 
السجل الحالي» ثم ينتقل منها إلى أداة أخرى.. هذا يتيح لك كتابة الكود 
المناسب لحفظ قيمة هذه الأداة في مصدر البيانات.. ولا تنسَ فحص القيمة 
ا ا ل و ود 

خطأ.. وسيكون من الجيد أن تمنع الخطأ من المنبع؛ > كالتالي: 
-١‏ استخدام الخاصية MaxLength‏ لتحديد أقصى طول لمربعات النصوص 
التي تستقبل نصوصا. . لقد وضعنا الرقم ٠‏ في هذه الخاصية في مربع 
النص الذي يستقبل اسم المؤلف. 
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؟"- وضع القيمة عنم1' في الخاصية 163000021797 لجعل مربع النص الذي 
يعرض رقم المؤلف ([ للقراءة فقط. 

۳- كتابة الكود المناسب في الحدث 11 في مربعات النص التي 
تستقبل أرقاماء لمنع كتابة أية حروف. 

-٤‏ استخدام أداة التاريخ والوقت :عع1[ء7721مة1ء12 لاستقبال التاريخ بدلا 
التواريخ في جدول العرض» بالطريقة التي تعلمناها في الفصل الخاص 
بجدول العرض. 

5- استخدام قائمة منسدلة لعرض أسماء الدول بدلا من السماح للمستخدم 
بكتابة رقم الدولة.. سأترك لك فعل هذا بنفسك» فقد فعلناه من قبل. 

1- استخدام مربع نص مقنن :7135160167190 لاستقبال رقم الهاتف 
بالصيغة الصحيحة (راجع مرجع برمجة الويندوز). 

لاحظ أنك لا تحتاج إلى حفظ التغييرات التي تحدث في سجلات جدول 

العرضء لأنها تحفظ تلقائيا بسبب ربطه بمصدر البيانات. 

و تش اطع لاله ”اداع ]1ع )ووم 72:01 كما في الحدث .ItenıValueNeeded‏ 


7 ف هل العنصر الحالي قذر :IsCurrentItem Dirty‏ 
تعيد 116 إذا كان المستخدم قد أجرى تعديلات على السجل الحالي في مكرر 
البيانات» دون أن تحفظ بعد في مصدر البيانات.. يحدث هذا إذا غير المستخدم 
قيمة إحدى الأدوات دون أن يغادرها. 


#2 تم حذف العنصر 166111519©111018:60: 
ينطلق هذا الحدث بعد حذف عنصر من مكرر البيانات» ليتيح لك حذف 
العنصر المناظر له من مصدر البيانات.. والمعامل الثاني ع لهذا الحدث من 
النوع ›DataRepeaterAddRemoveltemsEventArgs‏ وقد سبق أن 
تعرفنا عليه.. وقد استخدمنا هذا الحدث في المشروع VirtualRepeater‏ 
لحذف المؤلف من جدول المؤلفين كالتالي: 
BooksDataSet. Authors.Rows.RemoveAt(e.ItemIndex)‏ 
لاحظ أننا لا نحتاج على حذف كتب المؤلف ولن تحدث أية أخطاء لهذا.. 
السبب في هذا أننا عرفنا قيد المفتاح الفرعي التالي في حدث تحميل النموذج: 
Dim Fkc As New ForeignKeyConstraint(‏ 
BooksDataSet.Authors.[DColumn,‏ 
BooksDataSet. Books. AuthorIDColumn)‏ 
Fkc.UpdateRule = Rule.Cascade‏ 
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Fkc.AcceptRejectRule = Rule.Cascade 

Fkc.DeleteRule = Rule.Cascade 

BooksDataSet.Books.Constraints. A dd(Fkc) 

كما ترىء فقد عرفنا قاعدة الحذف المتتالى» لحذف كتب المؤلف تلقائيا بمجرد 

حذف المؤلف نفسه؛ وهذا يمنع حدوث أية أخطاءء ويوفر علينا كتابة كود 

الحذف.. كما عرفنا قاعدة التحديث المتتالي أيضا لمنع أية مشكلة عند حفظ 

بيانات المؤلف الجديد وتغير رقمه التلقائي.. والحقيقة أن المستخدم يجب ألا 

يدخل الكتب قبل حفظ المستخدم» وإلا فقد يخسرها بسبب عدم قبول قيمة الحقل 
0ا{ بعد تغير الرقم التلقائي للمؤلف. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


تفن 


42 فئة عنصر مكرر البيانات DataRepeaterItem Class‏ 


هذه الفئة ترث فئة اللوحة 61مه2» لهذا تستطيع احتواء أدوات أخرى»ء وهي تعمل 
كعنصر موضوع على مكرر البيانات» سواء كان العنصر المعروض في وقت 
التصميم (القالب)» أو العناصر المنسوخة منه في وقت التشغيل. 

وإضافة إلى ما ترثه من خصائص الأدوات التقليدية وخصائص الأداة الحاوية 
وخصائص اللوحة» تمتلك هذه الفئة الخصائص التالية: 


57 ف هل هو العنصر الحالي :IsCur ٣e٤‏ 
البيانات. 


57 فز هل هو قذر ر)¡1(9: 
تود مرا إذا كان المخد فد غير يعطن ينات التفين وام ا 


57 لون رقم العنصر e×‏ لہ[ :!٤)‏ 


وأهم ما يعنينا هناء هو كيفية التعامل مع الأدوات الموضوعة على العنصر.. كما 
ذكرنا من قبل» فإن العنصر هو لوحة [عرورج2» وهذا معناه أنه أداة حاوية؛ لهذا 
يمكنك استخدام الخاصية 0021015 للتعامل مع الأدوات الموضوعة عليه سواء 
بأرقامها أو بأسمائها.. ويكون التعامل مع الأدوات بأرقامها مناسبا إذا أردت المرور 
عبر كل الأدواتء بينما يكون التعامل مع الأدوات بأسمائها أكثر ملائمة للكود الذي 
يقرأ قيم الأدوات أو يغيرهاء لأنه يجعل الكود أكثر وضوحا وسهولة.. لاحظ أن 
الاسم الذي تمنحه للأداة في قالب العنصر في وقت التصميم» هو نفسه الاسم الذي 
ستستخدمه للتعامل مع نسخة الأداة الموضوعة على أي عنصر.. السبب في هذا أن 
كل عنصر هو نسخة طبق الأصل من القالب» وهذا معناه أن كل أداة موضوعة 
عليه تأخذ نفس خصائص نسختها الأصلية الموضوعة على القالب بما فى ذلك 
الاسم.. وعليك ألا ترتبك بين الاسم الموضوع في الخاصية مسج واسم المتغير 
الذي يشير إلى الأداة.. مثلا: الكود التالي يغير نص مربع النص الأصلي الموضوع 
على القالب: 

AuthorTextBox. Text = "Test" 
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ولن يؤثر هذا الكود على نسخ مربع النص الموضوعة على الأدوات» إلا إذا 
اسم تخدمته بين الوسسيتتين BeginResetItem Template‏ 
و EndResettem Template‏ كما أوضحنا من قبل. 
أما إذا أردت تغيير اسم المؤلف الحالي فقطء فيمكنك استخدام الكود التالي: 
Dim Itm = - 2-01‏ 
Dim AutherTxtBx = CType(‏ 
Itm.Controls(''"' Author TextBox'""), TextBox)‏ 
AutherTxtBx.Text = "Test"‏ 
وقد استخدمنا الكود التالي في المشروع 167621611661100101 لعرض كتب 
المؤلف في القائمة: 
Dim BksLst As ListBox = ]1)12.)020150'1500151151''(‏ 
BksLst.DataSource = Books View‏ 
BksLst.DisplayMember = "Book"‏ 
كما استخدمنا الكود التالي في حدث ضغط زر عرض كتب المؤلف الموضوع على 
قالب العنصر: 
Dim Itm = - 2-01‏ 
الحصول على كائن عرض صف المؤلف الحالي ' 
Dim Rv = BooksDataSet.Authors.DefaultView(Itm.ItemIndex)‏ 
الحصول على كائن عرض يحتوي على كتب هذا المؤلف ' 
Dim RI = BooksDataSet.Authors.ChildRelations(0)‏ 
Dim BooksView = Rv.CreateChildView(RI)‏ 
عرض الكتب في جدول العرض ' 
FrmBooks.GrdBooks.DataSource = Books View‏ 
& " كتب" = FrmBooks. Text‏ 
Itm.Controls("" Author TextBox"). Text‏ 
FrmBooks.ShowDialog( )‏ 
لاحظ أن كل نسخ الزر تستجيب أيضا لهذا الحدث.. ألم أقل لك إن نسخة الأداة 
مماثلة للأداة الأصلية فى كل شىء؟.. هذا يشمل الإجراءات المستجيبة لأحداث 
الأداة» لهذا تستطيع برمجة أحداث الأدوات الموضوعة على قالب العنصر مباشرة 
وستكون بذلك قد برمجت أحداث كل النسخ المنسوخة من هذه الأداة. 
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خاتمة- 
إلى هناء نكون قد وصلنا إلى نهاية رحلتنا مع مكرر البيانات» وإلى نهاية هذا 
الكتاب أيضا.. لكن رحلتنا مع قواعد البيانات لم تنته بعد» فما زالت أمامنا بعض 
المواضيع المتقدمة التي سنتعرف عليها في الكتاب التالي بإذن اللّه» مثل: 
- التعاملات .Transactions‏ 
- استخدام الاستعلام المتكامل مع قواعد البيانات 501 10 Qہ11.‏ 
- إطار عمل الكينونات .Entity Framework‏ 
د .عتاصسز قو اعد البيانات السذارة مكل الإأحراءات المخزفة المنذارة 
.Managed Stored Procedures‏ 
التقارير الجاهزة .Crystal Reports‏ 
فإلى الملتقي في كتاب "المواضيع المتقدمة في برمجة قواعد البيانات" بإذن الله. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


1Y7 


ملحق: ۲ 
أنواع بيانات سيكويل المدارة 
Managed SQL Data Types‏ 


يمنحك النطاق System. Data.Sq1Types‏ عددا من السجلات Structures‏ 
والفنات 0135565 التي تمثل أنواع البيانات الخاصة بخادم سيكيول.. هذا يسهل 
عليك إرسال واستقبال البيانات عند التعامل مع قواعد بيانات سيكيول. 
وفيما يلى» نتعرف على هذه السجلات.. لا تنس إضافة الجملة التالية أعلى صفحة 
الكودء قبل تجربة أي مثال في هذا الفصل: 
Imports System.Data.SqITypes‏ 

وستجد أمثلة على بعض هذه الأنواع في المشروع كعم رآ4ا124¶؟. 
وتفيدلك هذه الأنواع عند التعامل مع الفئة ›Sg] (ata R eder‏ فهي تمتلك مجمو عة 

من الوسائل Methods‏ التي تقرأ البيانات من الجدول» وتعيدها إليك في صورة 
واحد من هذه الأنواع المدارة. . على سبيل المثال» يمكنك استخدام الوسيلة 
SqlDataReader. GetSqlDecimal‏ لقراءة البيانات من عمود يحتوي على 
أعداد عشرية» حي تعيد هذه الوسيلة القيمة في متغير من النوع 72[1اعء50110.. 
وستتعرف على هذه الوسائل في الفصل التاسع. 
لاحظ أن جميع الأنواع التي سنتعرف عليها هنا تمثل الواجهة 121011361» لهذا 
فهي تستطيع أن تحتوي القيمة 2[111» مما يعني أن الخانة التي يتعامل معها الكائن 
في قاعدة البيانات فارغة.. كما يعني أن جميع هذه الأنواع تمتلك الخاصية 
152111» التي تعيد عنم1 إذا كان الكائن فارغا (يحتوي على 71011)» وفي هذه 
الحالة يجب ألا تحاول قراءة قيمة هذا الكائن» وإلا حدث خطأ في البرنامج. 


038 


اک سجل القيمة المنطقية SqlBoolean Structure‏ 


يستطيع هذا السجل أن يحتوي على قيمة منطقية: عنم أو ع5215. 
ولحدث إنشاء هذا ا لسجل ثلاث صيغ: 
؟. والثانية تستقبل قيمة منطقية ه2001 لوضعها في السجل.. مثال: 
Dim Sb As New 5011500162110 1111 (‏ 
". والثالثة تستقبل عددا صحيحا Integer‏ لوضعه في هذا السجل» حيث يعتبر 
الصفر ع1215 وأي عدد آخر 15106. 
ولك ها السكل الختا التالية: 


5 اتا خطأ eی[۴a:‏ 
تعيد سجلا منطقيا ے01 $٩180‏ قيمته ع1'215. 


5 لعا صواب ع1:1: 
تعيد سجلا منطقيا مرهء50128001 قيمته 11116. 


5 لعا عدم :Null‏ 
تعيد سجلا منطقيا مرهء50128001 قيمته 11111. 


چ اا صفر ۰7۲0 
تعيد سجلا منطقيا 5٩180014‏ قيمته ٠‏ (هذا يعني أن قيمته ©1215). 


5 لعا واحد عم0: 
تعيد سجلا منطقيا 8٩18001٥21‏ قيمته ١‏ (هذا يعني أن قيمته ع1::1). 


57 ف هل هو خطأ [e‏ 1۹۴: 
تعيد 116 إذا كانت قيمة السجل الحالي موإم۴. 


ف هل هو صواب ع19:11:1: 
تعيد 116" إذا كانت قيمة السجل الحالي ©111'. 


TVA 


ف القيمة eںuاو۷:‏ 
تعيد قيمة منطقية 8001621 تعبر عن قيمة السجل الحالي.. وتسبب هذه 
الخاصية خطأ إذا كان السجل منعدماء لهذا عليك فحصه أولا باستخدام 
الخاصية 192711 قبل استخدام هذه الخاصية. 


557 فز القيمة الرقمية 1373)217216: 
تعيد وحدة ثنائية 13376 تعبر عن قيمة السجل الحالي (صفر للخطأ و ١‏ 
للصواب).. وتسبب هذه الخاصية خطأ إذا كان السجل منعدماء لهذا عليك 
فحصه أولا باستخدام الخاصية 15111 قبل استخدام هذه الخاصية.. مثال: 

If Not Sb.IsNull Then 

MsgBox(Sb.ByteValue) ' 1 

MsgBox(Sb.Value) ' True 
End If 


ويمتلك هذا السجل المعامالات Operators‏ اللازمة لإجراء العمليات الحسابية 
والمنطقية اللازمة.. كما أنه يمتلك وسائل مشتركة 37416157005 513160 لأداء نفس 











المناظرة لها: 
المعامل الوسيلة 
And And‏ 
Or Or‏ 
Xor Xor‏ 
OnesComplement Not‏ 
(المعكوس الثنائي) 
Equals =‏ 
NotEquals <>‏ 
GreaterThan >‏ 
GreaterThanOrEquals | >=‏ 
LessThan <‏ 
LessThanOrEquals >=‏ 


كما يمتلك هذا السجل عدة وسائل للتحويل» مثل* 


ToSqlByte 0 ToString 9 
ToSqIDouble ™# ToSqIDecimal ™# 
ToSqlInt32 1# ToSqlInt16 # 


1۷۹ 






































ToSqlMoney 9 14 9 
ToSqlString # ToSqISingle W 
Parse WS 


انظر المثال التالي: 

Dim Sb = SqIBoolean.Parse("'false"") 
Dim B As SqlByte = Sb.ToSqlByte 
MsgBox(B.ToString) ' 0 
مع ملاحظة أنك لا تحتاج إلى استخدام هذه الوسائل» لأن هذا السجل يعرف أيضا‎ 
معاملات التحويل الضمني 01661214015 11016م1نآ ومعاملات التحويل الصريح‎ 
اللازمة لتحويل القيم الأخرى إلى هذا السجلء أو تحويل‎ Expاicit‎ 5 

هذا السجل إلى قيم أخرى مباشرة.. مثال: 
Dim 501 As SqlBoolean = "true"‏ 
Dim B1 As SqlByte = Sb1‏ 
MsgBox(B1.ToString) ' 1‏ 


ملحوظة: 

كل الأنواع التي سنشرحها فيما بعد مزودة بالمعاملات الحسابية 
(الطرح والجمع والضرب والقسمة وباقي القسمة) والمعاملات المنطقية 
(0نث و +0 و +2201 و )N0‏ ومعاملات التحويل الضمني والصريح.. ولا 
يحتوي كل نوع إلا على المعاملات التي تناسب القيم الموجودة فيه 
(النصوص متلا لا تملك معاملات منطقية)ء لهذا لن نكرر ذكر هذا في باقي 
الأنواع» إلا إذا كان هناك معامل يقوم بوظيفة مختلفة عن المألوف. 
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أ سجل الوحدة الثنائية Structure‏ 50113316 


هذا السجل يحفظ وحدة ثنائية بدون إشارة»ء أي أنه يتعامل مع الأعداد 
عن ال 120 
ويستقبل حدث إنشاء هذا السجل وحدة ثنائية 836 لنسخ قيمتها إليه.. مثال: 

Dim B As New 501151 (5) 


زك هذا السكل الختا اة 


ع لعا أقل قيمة :MinValue‏ 
تعيد أقل قيمة يمكن وضعها في السجل. 


© لعا أقصى قيمة :M 4×۷ [ue‏ 
تعيد أكبر قيمة يمكن وضعها في السجل. 


© لما صفر ۰7٥۲0‏ 
تعيد نسخة من السجل 50115316 تحتوي على القيمة صفر. 


5 لعا العدم :Nul1‏ 
تعيد نسخة من السجل 501283:6 لا تحتوي على أي قيمة. 


57 ف القيمة مuاو۷:‏ 
عبد رحد د عة عمال ااا اتسر فى الس وتسيب م 
الخاصية خطأ في البرنامج إذا كان السجل منعدماء لذا عليك أن تستخدم 
الخاصية 19371011 أولا للتأكد من وجود قيمة في السجل. 


لاحظ أن ما ينطبق على السجل 501836 ينطبق على السجلات الرقمية الأخرىء 
فهي تمتلك نفس الخصائص» وتستطيع حفظ قيمة أو 7[1011» والاختلاف الوحيد هو 
نوع القيمة المحفوظة.. لذا فلا داعي لتكرار نفس الكلام مع الأنواع التاليةء فأنت 
تستطيع فهمها بمجرد النظر: 


أك سجل الأعداد القصيرة Structure‏ 50110416 

كا سجل الأعداد الصحيحة Structure‏ 50112032 

ك سجل الأعداد الطويلة Structure‏ 50112464 

ا ا سجل الأعداد المفردة SqlSingle Structure‏ 

أيحد ك2 سجل النقود SqIMoney Structure‏ 

ا > سجل الأعداد المزدوجة SqlDouble Structure‏ 
د سجل التاريخ والوقت SqIDate Time Structure‏ 
أيحم سجل المعرف المتفرد العام SqlGuid Structure‏ 


ت سجل الأعداد العشرية SqlDecimal Structure‏ 


يحفظ هذا السجل الأعداد العشرية» بنفس طريقة السجل 1وص¡ء 06 كما أن حدث 
إنشاء هذا السجل يمتلك صيغا شبيهة بحدث إنشاء السجل 35721ع1(6» التى يمكنك 
مراجعتها في كتاب برمجة إطار العمل. 1 
ويزيد هذا السجل على سجلات الأنواع العددية الأخرى بالخصائص التالية: 


5 لما أقصى دقة :MaxPrecision‏ 
يعيد أقصى عدد من الخانات الصحيحة والعشرية يمكن استخدامه في العدد. 


© اا أقصى مقياس »113:2562[1: 
يعيد أقصى عدد من الخانات العشرية يمكن استخدامه في العدد. 


57 فط البيانات الثنائية 1171(212: 


57 ف البيانات 12262: 
تعيد مصفوفة أعداد صحيحة :437833 ١ءعء)م]‏ تحتوي على التمثيل الثنائي 
للعدد العشري. 


فط هل هو موجب 20910106 19: 
تعيد 1106 إذا كان العدد العشري موجبا. 


7 فور الدقة ررمزوزععمرط: 
تعيد عدد الخانات الصحيحة والعشرية في العدد الحالي. 


57 فل المقياس 50216: 
تعيد عدد الخانات العشرية في العدد الحالي. 


SqIChars Class فئة الحروف‎ 4 


هذه الفئة تتعامل مع مصفوفة حروف» بحيث يمكن استخدامها للتعامل مع أنواع 
سيكيول التالية: varchar, nvarchar, char, nchar, text, next‏ <« مع 
ملاحظة أن أقصى عدد من الحروف يمكن وضعه فى هذه الفئة هو أقصى قيمة 
للعدد الصحيح (أي حوالي ۲ مليار حرف). 1 
ولحدث إنشاء هذه الفئة ثلاث صيغ: 

.11011 الأولى بدون معاملات» وهي تنشئ نسخة قيمتها‎ .١ 

؟. والثانية تستقبل مصفوفة حروف .Char Aa‏ 

۳. والثالثة تستقبل نسخة من السجل 50151106 لأخذ الحروف من النص 

الموجود فيها. 


وتمتلك هذه الفئة الخصائص التالية: 
و العدم :Null‏ 


تعيد نسخة فار غة من الفئة 50101215. 


7 العنصر «رع)1: 
هذه هي الخاصية الافتراضية 61167م821720 106191116 وهي تقرأ أو تغير 
الحرف الموجود في الموضع المرسك كمعامل: 

7 ف الطول ٤ع :Le‏ 
تعيد عدد الحروف الموجودة حاليا في الكائن. 


557 ف أقصى طول :MaxLength‏ 
تعيد أقصى عدد من الحروف يمكن وضعه في الكائن.. هذا العدد يساوي 
صفرا مبدئياء لكنه يساوي طول النص عند وضع نص في الكائن.. وعند 
تقصير طول الكائن» يظل أقصى طول كما هو دون أن ينقص. 


7 فع التخزين :Storage‏ 
تعيد إحدى قيم المرقم StorageState‏ التي توضح نوع المخزن الذي يتم فيه 
كك اروف داخل الكائن» وهذه القيم هي: 

Buffer‏ تحفظ الحروقه في مصفوفة 3اخلية. 
UnmanagedBuffer‏ | تحفظ الحروف في الذاكرة باستخدام مؤشرات 
غير مدارة باطار العمل. 
Stream‏ تحفظ الحروف في مجرى بيانات 51]56211. 


7 فع المخزن الوسيط rم]Buff:‏ 
تعيد مصفوفة الحروف التي يتعامل معها الكائن داخليا.. لاحظ أن أي تغيير 
في هذه المصفوفة يؤثر على محتويات الكائن. 

57 يوز القيمة مuام۷:‏ 
هذه المصفوفة لا يؤثر على محتويات الكائن» على عكس المصفوفة التي 
تعيدها الخاصية Buffer‏ . 











كما تنتلك فقة الخروف الوسائل القالية: 


7# تغيير الطول :SetLength‏ 
أرسل إلى هذه الخاصية عدد الحروف الذي تريد وجودها في الكائن.. لاحظ 
أنك لو أرسلت عددا أكبر من أقصى طول MaxLength‏ فسيحدث خطأ.. 
هذا معناه أنك تستطيع تصغير محتويات الكائن» حيث سيتم حذف الخورف 
الزائدة عن الطول الجديد» لكن ستظل المصفوفة الداخلية تحجز الخانات التي 
تم الاستغناء عنهاء لهذا تستطيع أن تكبر الطول مرة أخرى» بشرط عدم 
تجاوز الطول الأقصى. 
ولو كان الكائن يتعامل مع مخزن وسيط غير مدار Unmanaged Buffer‏ 
فسيتم تحويله إلى مخزن مدار 811141 21322860 بعد تنفيذ هذه الوسيلة. 


7# وضع العدم :SetN ul]‏ 
تمحر موا الكائن اللكالى ر تن ر اترا 














ب 


قراءة Rea‏ : 
تنسخ عددا من الحروف من الكائن الحالي إلى مصفوفة؛ ولها المعاملات 
التالية: 
- موضع بداية القراءة من الكائن. 
- مصفوفة الحروف التي سيتم النسخ إليها. 
5 موظيع يداية الكقاية فى المصفوقة. 
- عدد الحروف المنسوخة. 
وتعيد هذه الوسيلة عدد الحروف التي تم نسخها. . الحكمة في هذا أن عدد 
الحروف المنسوخة قد يكون أقل من المطلوبء إذا لم يكن الكائن يحتوي على 
العدت المظلوي من الكروفة. 
والمثال التالي ينسخ 5 حروف من الكائن بدءا من الحرف الرابع: 
Dim Sc As New SqlChars('This is a test")‏ 
Dim C(4) As Char‏ 
Sc.Read(3, C, 0, 5)‏ 
MsgBox("'"" & C & N)‏ 


كتابة :Write‏ 
تنسخ عددا من الحروف من مصفوفة إلى الكائن الحالي بدءا من موضع 
معين.. ولها نفس معاملات الوسيلة السابقة. 
لاحظ أنك تستطيع كتابة حروف في موضع تال لآخر حرف في الكائن» 
بشرط ألا تتجاوز الطول الأقصى للكائن جاع 6.آ:27/]2. 
والمثال التالي ينسخ كل حروف المصفوفة إلى الكائن بدءا من الحرف الرابع: 
Dim Sc As New SqlChars('This is a test")‏ 
Dim X0 As Char "A"c, "B"c, "Ee; "D"c, "E"c}‏ 
Sc.Write(3, X, 0, 5)‏ 
MsgBox(Sc.Value)‏ 


التحویل إلى نص سیکویل 105015):125: 
تعيد نسخة من السجل 50151118 تحتوي على نص مكون من حروف الكائن 


الحالي. 


SqlString Structure سجل النص‎ = 


يختلف نص سيكويل في طريقة تمثيله الداخلية» عن فة النص 001855 511108 
العادية.. فعلى سبيل المثال: يأخذ النص العادي معلومات الثقافة من اللغة 
الافتراضية المعرفة على جهاز المستخدم» بينما لا يفعل نص سيكويل هذاء فلو لم 
تمده بمعرف الثقافة» فإنه يستخدم مقاييس داخلية خاصة به لمقارنة النصوص.. ولو 
حاولت مقارنة نسختين من نص سيكويل لكل منهما معرف ثقافة (1.0011 مختلف 
عن الآخرء. فإن خطأ سيحدث في البرنامج بسبب عدم قدرته على إجراء عملية 
المقارنة. 
(أنصح بمراجعة فصل العولمة 0106211736105 في مرجع برمجة إطار العمل). 
ولحدث إنشاء هذا السجل الصيغ التالية: 
.١‏ الأولى بدون معاملات» وهي تنشئ نسخة قيمتها 1إاں. 
؟. والثانية تستقبل نصا String‏ لنسخه إلى السجل. 
*. والثالشة تزيد على الصيغة السابقة بمعامل ثان يستقبل معرف الثقافة 
0 الذي تريد استخدامه عند مقارنة النص بأي نص آخر.. مثال: 
System.Globalization.‏ ''محمد ")5015111115 Dim Ss As New‏ 
CultureInfo.CurrentCulture.LCID)‏ 
.٤‏ والرابعة تزيد على الصيغة السابقة بمعامل ثالث» يستقبل إحدى قيم المرقم 
Sq] ompareOptions‏ التالية: 


None‏ تتم المقارنة بالخيارات الافتراضية للثقافة التي 
يرتبط بها السجل الحالي. 

05+ /تتجاهل المقارنة حالة الأحرف. 
gn0oreNonSpaceا ‏ تتجاهل المقارنة كل الرموز التي لا تعتبر 


فواصل بين الحروف» مثل علامات التشكيل 
في اللغة العربية.. هذا مفيد عند البحث عن 


كلمة مع تجاهل التشكيل. 
613217390 | تتجاهل المقارنة الرموز الصوتية في اللغة 
اليابانية. 
226110 تتتجاهل المقارنة إن كانت الحروف اليابانية 
مكتوبة بالعرض الكامل أم بنصف العرض. 





























11 ايتم ترتيب الحروف تبعا لقيمها الرقمية في ترميز 
511 أو ع1000م[]ء وليس تبعا للترتيب الهجائي. 
02 | يتم ترتيب الحروف ثنائياء باستخدام قيمها في 
الترميز. 


لاحظ أنك تستطيع دمج أكثر من قيمة معا باستخدام المعامل :0. 
5 ومصفوفة ثنائية 13237 8366 تحتوي على 
التمثيل الثنائي للنص. 

؟. والسادسة تزيد على الصيغة السابقة بمعامل رابع» عليك جعله عدم7 إذا 
كان النص ممثلا بالترميز الموسع ©1[5110006. 

۷. والسابعة تزيد على الصيغة الخامسة بمعامل رابع يستقبل موضع بداية 
القراءة من المصفوفة؛ ومعامل خامس يستقبل عدد الحروف التي تريد 
قراءتها منها. 

6. والثامنة تزيد على الصيغة السابقة بمعامل رابع» عليك جعله ه11 إذا كان 
النص ممثلا بالترميز الموسع 1[010006]. 











5 7 فط ترتيب ثنائي :01 8122175: 
تعمل كثابت يعني أن ترتيب الحروف يتم تبعا لقيمها الرقمية في ترميز 
1 وليس تبعا للترتيب الهجائي. 


5 7 فط ترتيب ثنائي 231217:501:02: 
تعمل كثابت يعني أن ترتيب الحروف يتم تبعا لقيمها الرقمية في الترميز. 


© ف تجاهل الحالة ع15001:»025: ٠‏ 
تعمل كثابت يعني أن مقارنة الحروف تتجاهل حالتها (صغيرة أم كبيرة). 


5 فط تجاهل الحروف غير الفاصلة :IgnoreNonS pace‏ 
تعمل كثابت يعني أن المقارنة تتجاهل كل الرموز التي لا تعتبر فواصل بين 
الحروف: مثل علامات التشكيل في اللغة العربية. 











5 733 فيز تجاهل نوع الكانا 150 15201:612222: 
تعمل كثابت يعني أن مقارنة الحروف تتجاهل الرموز الصوتية في اللغة 
اليابانية. 


5 37 ف تجاهل العرض :Ignore Width‏ 
تعمل كثابت يعني أن مقارنة الحروف تتجاهل إن كانت الحروف اليابانية 
مكتوبة بالعرض الكامل أم بنصف العرض. 


5 و العدم :Null‏ 
تعيد نسخة فارغة من السجل ع110ا50151. 


57 ف معلومات الثقافة o‏ گم[ءCultur:‏ 
تعيد كائن معلومات الثقافة 0016061710 الذي يستخدمه السجل الحالي في 
تنسيق وترتيب ومقارنة النصوص. 


57 ف المعرف المحلي للثقافة :]٣1(‏ 
تعيد عددا صحيحا يستخدم كمعرف للثقافة التي يتعامل معها السجل الحالي. 


57 ف معلومات المقارنة oگCompareInf:‏ 
تعيد كائن معلومات المقارنة CompareInfo‏ الذي يستخدمه السجل الحالي 
في مقارنة النصوص. 


57 فز خيارات المقارنة :SqICompareOptions‏ 
تعيد إحدى قيم المرقم 1105م8 501001703160 التي توضح الخيارات 


57 ف القيمة 172116: 
تعيد String‏ يمثل النص الموجود في السجل الحاليء أو تسبب خطأ إذا كان 
السجل فارغا. 


ويمتلك هذا السجل الوسائل الهامة الثالية: 


5 # تشبيك )0202): 
تدمج نسختين من نص سيكيول في نص واحد» وتعيده كسجل جديد.. مثال: 
Dim LCID = System.Globalization.‏ 
CultureInfo.CurrentCulture.LCID)‏ 
Dim 551 As New SqIString(''ıa<n'"", LCID)‏ 
LCID)‏ ,"محمود Dim 552 As New SqIString('‏ 
Dim Ss3 = SqlString.Concat(Ss1, Ss2)‏ 
محمد محمود ' MsgBox(Ss3.V alue)‏ 
ويمكنك إنجاز نفس المهمة باستخدام الوسيلة إل كالتالي: 
Dim 553 = SqlString.Add(Ss1, Ss2)‏ 
أو باستخدام معامل الجمع كالتالي: 
Dim Ss3 = Ss1 + Ss2‏ 


& 7# خيارات المقارنة من خيارات مقارنة سيكويل 
:CompareOptionsFromSqlCompareOptions‏ 
أرسل إلى هذه الوسيلة إحدى قيم المرقم وومزأام0١إةم $۹1٥٠‏ لتعيد إليك 
القيمة المناظرة لها في المرقم 61005م31600م0022) الذي تعرفنا عليه في 
كتاب برمجة إطار العمل. 


4 نسخ :Clone‏ 
تعيد نسخة جديدة من السجل 5015328 بها نفس قيمة السجل الحالي. 


#أ> قراءة البيانات غير الموسعة :GetNonUnicode Bytes‏ 
تعيد مصفوفة ثنائية 41183 183565: تحتوي على تمثيل النص الحالي في 
ترميز 11 .A8€‏ 


7# قراءة البيانات الموسعة :GetUnicode Bytes‏ 
تعيد مصفوفة ثنائية 11237 «Bytes‏ تحتوي على د ثيل النص الحالي في 
ترميز ع01600لآ. 


اح سجل البيانات الثنائية Structure‏ 501181021 


يمثل هذا السجل مصفوفة من الوحدات الثنائية 13237 م)ر8.. ويمكنك ملء هذا 
السجل بالبيانات بإرسال مصفوفة ثنائية إلى حدث إنشائه.. مثال: 
Dim 501 As New SqlBinary({100, 220, 3})‏ 
ونظرا لأن هذا السجل يعرف معامل التحويل الضمني 07618601 «Implicit‏ 
فيمكنك وضع مصفوفة ثنائية في هذا السجل مباشرة: 
Dim Sb2 As SqlBinary = {1, 0, 2}‏ 


لحا القيمة المنعدمة 1011 : 
تعيد سجلا فارغا.. مثال: 
Dim Sb3 = SqIBinary.N ull‏ 


57 فيز الطوال ط٤ :Le ng‏ 
تعيد عدد الوحدات الثنائية الموجودة في السجل.. مثال: 
MsgBox(Sb1.Length) ' 3‏ 


57 لز العنصر ہع)!: 
هذه هي الخاصية الافتراضية للسجل 117عم2710 ١106181116‏ وهي تعيد الوحدة 
الثنائية ]837 الموجود في موضع معين في السجل.. مثال: 
MsgBox(Sb1.Item(0)) ' 0‏ 
MsgBox(Sb1(1)) ' 0‏ 
المؤسف أن هذه الخاصبية ثلقزاءة ققظه لذا قلا ينكنك استخدامها لكشيو 
العنصر الموجود في موضع معين من المصفوفة.. ولست أدرى ما الحكمة 
من هذا! 


557 ف القيمة مuاو۷:‏ 
تعيد مصفوفة ثنائية 41737 8316 تحتوي على القيم الموجودة في السجل 
الحالي. 


كما يمتلك هذا السجل عددا من الوسائل المشتركة 5123160» وهي تقوم بنفس 
وظائف المعاملات 006136015) المعرفة لهذا السجل.. ويهمنا هنا أن نشير إلى 
بعضها لآن طريقة عملها مختلفة نوعا: 
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5 # إضافة 400: 
5 # تشبيك )1وع0): 
س 
ع بدت المعامل + ٠‏ 
تقوم بتشبيك سجلين» بدمج المصفوفة الثانية بعد نهاية المصفوفة الأولى؛ 
وتعيد المصفوفة الجديدة في سجل جديد.. مثال: 
Dim Sb = SqlIBinary.Add(Sb1, Sb2)‏ 
أو : 
و: 
Dim Sb = SqlBinary.Concat(Sb1, Sb2)‏ 
أو باختصار: 
Dim Sb = 551 + 2‏ 
بعد تنفيذ هذا المثال» سيحتوي سجل البيانات الثنائية 86 على القيم التالية: 
oT YY Noe‏ ا Toe‏ 
© # يساوي واھو۴Eu:‏ 
س 
© ببح المعامل = ٠‏ 
تعيد ٥ں‏ إذا كان السجلان لهما نفس الطول ويحتويان على نفس القيم 
بنفس الترتيب.. مثال: 
MsgBox(SqlBinary.Equals(Sb1,Sb2)) ' False‏ 
أو باختصار: 
MsgBox(Sb1 = Sb2) ' False‏ 
لاحظ أن القيمة العائدة من هذه الوسيلة هي من النوع 50180116» حيث 
تكون نتيجة المقارنة 77111 إذا كان أي من السجلين منعدما. 
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4 فئة الوحدات الثنائية 1255© 501135465 


هذه الفئة مشابهة بدرجة كبيرة للسجل /501191818» إلا أنها تمتلك ميزة إضافيةء 
وهي قدرتها على التعامل مع الوحدات الثنائية و8376 من خلال مجرى بيانات 
دوع 5.. هذا يتيح لك قراءة البيانات من ملف «رروع11165 أو من مجرى 
بيانات الذاكرة MemoryStreanı‏ أو من خلال الشبكة .NetworkStream‏ 
ولت اق :هذه قلسي اله 

.١‏ الصيغة الأولى بدون معاملات. 

؟. والثانية تستقبل بياناتها من مصفوفة ثنائية 1723ل عالا8. 

". والثالثة تستقبل بياناتها من سجل بيانات ثنائية ,5همؤ5018. 

.٤‏ والرابعة تستقبل بياناتها من مجرى بيانات 77هع5]1. 
وتشبه هذه الفئة أيضا الفئة 15 في كل خصائصها ووسائلهاء ما عدا أن 
التعامل هنا يكون مع مصفوفة ثنائية 411237 8316 بدلا من مصفوفة حروف 
..Char Array‏ لهذا لا نحتاج إلى إعادة شرح هذه الخصائص والوسائل: 
5 و العدم Null‏ 57 فيز هل هو منعدم 15170111 
5 العنصر ہ٥٤!‏ ف الطول Length‏ 
57 ف أقصى طول [)ع ».212:1 2 "ف التخزين ©51601:286 
57 فخ المخزن الوسيط Buffer‏ ف القيمة ١7106‏ 
2# تغيير الطول ط٤ Seg‏ 7# وضع عدم SetNull‏ 
9ت قراءة Read‏ 7# كتابة Write‏ 


الجديد فقط هو الخاصية والوسيلة التاليتان: 


3 مجرى البيانات «رردع5)1: 
تقرأ أو تغير مجرى البيانات الذئ يتعامل مه الكائن الحالي.. ويؤدي استخداء 
كد الخاضية إلى تسن ك الياناك من محر البيانات لے ا 
كانت هذه البيانات ضخمة للغايةء فقد تؤدي إلى استهلاك مساحة الذاكرة 
وحدوث خطأ من النوع .OutOfMemoryException‏ 


ب التحويل إلى بيانات ثنائية "4y‏ ¡08¶18آ: 


تعيد سجل بيانات ثنائية 5018102157 يحتوي على الوحدات الثنائية ومر 
الموجوؤذة في الكائن الحالي. 
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XML i ê 
SqIXmIl Class 


تحفظ هذه الفئة وثيقة ,7701» وهي تعتمد داخليا على "قارئ بيانات 30/1" 
»×m]R eder‏ لهذا يجب مراعاة أن يكون تنسيق بيانات ,75341 الذي تضعها في 
هذه الفئة موافقا للمعايير التي تقبلها الفئة 1©ع20711620.. وسنتعرف على كيفية 
التعامل مع بيانات 11> وفئاتها في كتاب مستقل بإذن الله. 
ولحدث إنشاء هذه الفئة ثلاث صيغ: 

-١‏ الأولى بدون معاملات. 

۲- والثانية تستقبل البيانات من مجرى بيانات 17هع5]1. 

۳- والثالثة تستقبل البيانات من "قارئ .XmlReader "XML‏ 


وتمتلك هذه الفئة الخصائص التالية: 


5 و العدم :Null‏ 
تعيد نسخة من الفئة 50131 لا تحتوي على أي قيمة. 


57 ف القيمة 172111: 
تعيد نصا ع5 يحتوي على وثيقة 7532/1 المحفوظة في الكائن الحالي. 


كما شتلك هذه الفكة الوسسيلة الثالية: 


> إنشاء قارئ :CreateReader‏ 
تعيد "قارئ ,21/1" X×m]Reader‏ لاستخدامه في قراءة محتويات الكائن 
الحالي. 


ملحوظة: 
كل أنواع بيانات سيكويل السابقة تدعم التعامل مع »×M1‏ من خلال: 
- تمثيل الواجهة »13156112112261 لحفظ محتويات الكائن في وثيقة 
N1‏ وقراءتها منها في أي وقت. 
- امتلاك وسيلة مشتركة Shared Method‏ اسمها «GetXsdType‏ 
تستقبل "نوع مخطط ,21/1" 3015016112561» وتعيد نسخة من الفئة 
عمطه101121116011مما تحتوي على الاسم الكامل لنوع ,52341 المناظر. 


حفظ الملفات خارج قاعدة البيانات: 
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يقدم لك سيكيول سيرفر ۲۰٠۸‏ إمكانية رائعة» وهي قدرتك على حفظ البيانات 
الثنائية الضخمة 81,013 (تكون في الغالب أكبر من ١‏ ميجا بايت) التي ترسلها 
إلى عمود من النوع (7311313)31736 في ملف خاص مستقل عن ملف قاعدة 
البيانات» يتم حفظه في مجلد خاص على الخادم.. هذا يحقق لك الفوائد التالية: 
-١‏ يضمن عدم تضخم حجم ملف قاعدة البيانات بصورة كبيرة. 
- يقلل من الزمن اللازم لقراءة هذه البيانات. 
"- يستطيع النوع (7310813:)5]476 حفظ بيانات حجمها تقريبا ۲ جيجا 
بايت في قاعدة البيانات» بينما عند استخدام ملفات خارجية لا يكون هناك 
اي حد لجم الملفء إلا مقدار المساحة المتوفرة على القرص الصلب! 
-٤‏ قدرتك على التعامل مع هذه الملفات من خلال استعلامات قاعدة البيانات؛ 
أو التعامل معها مباشرة من خلال نظام ملفات الويندوز 
Windows File System‏ . 
-٥‏ تقدم لك دوت ت ۲١٠١‏ فئة خاصة للتعامل مع البيانات المحفوظة خارج 
قاعدة البيانات» وهي الفئة «رهء۲ا؟ ]$41۴1 التي سنتعرف عليها لاحقا. 
وهناك أربع خطوات عليك اتباعهاء حتى تستطيع حفظ قيم الأعمدة الضخمة في 
ملفات مستقلة.. هذه الخطوات هي: 


- تفعيل استخدام مجرى البيانات 1711,1:5:11210411/1 في خدمات الويندوز: 
يتم هذا كما يلي: 
- من قائمة البرامج ›Programs Menu‏ اضغط: 
Microsoft SQL Server 2008\Configuration 10015١‏ 
SQL Server Configuration Manager‏ 
- في الشجرة اليسرى في نافذة تهيئة خادم سيكويل» انقر العنصر 
8Q1 Server Services‏ مرتين بالفأرة. 
- في القائمة اليمنى» حدد اسم خادم سيكويل الذي تتعامل معه. . في حالتنا هذه 
سيكون (8؟٤XPR×٤Server)SQ1 SQL‏ » وانقره مرتين بالفأرة 
لعرض خصائصه. 
- في نافذة الخصائص»› اض خط الشريط العلوي Tab‏ المسمى 
۴ER EM‏ لعرض صفحة خصائصه. 
- ضع علامة الاختيار أمام الاختيار: 
Enable FILESTREAM for Transact-SQL access‏ 
هذا سيتيح لك قراءة وكتابة الملفات الخارجحية من خلال الاستعلامات. 
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Log On | Service FILESTREAM | advanced | 


¥ Enable FILESTREAM for Transact-SQL access 


I¥ Enable FILESTREAM for file O streaming access 


Windows share name: | SQLEXPRESS 


IV Allow remote clients to have streaming access to 
FILESTREAM data 





OK | Cancel | Apply | 





إذا وضعت علامة الاختيار أمام الاختيار: 

Enable FILESTREAM for file [O streaming access 
فسيتيح هذا لك القراءة من الملفات الخارجية من خلال نظام مشاركة‎ 
الملف مباشرة بدون استعلامات» كأنك تتعامل مع أي ملف عادي على‎ 
الشبكة» وهو ما سنفعله باستخدام الفئة 70هع501111656.. ويجب عليك أن‎ 
تكتب في مربع النص اسم مجلد المشاركة الذي ستقرأ الملف من خلاله..‎ 
لکن‎ ؛SQ‎ ٤× ۴R ٤88 في الوضع الافتراضي يكون هذا الاسم هو‎ 
يمكنك تغييره إلى ما تشاء.‎ 


إذا وضعت علامة الاختيار أمام الاختيار: 

Allow remote clients to have streaming access to FILESTREAM 
Remote Users فسيسمح هذا للمستخدمين من خار ج الشبكة المحلية‎ 
بقراءة بيانات الملف عبر نظام مشاركة الملفات.‎ 
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ملحوظة هامة: 
يشكو كثير من المستخدمين عند استخدام الفئة 81۴1٥5٤٥4۳‏ من أن 
رسالة خطا تظهر لهم تخبرهم بأن مسار الملف غير موجود على 
الشبيكة:. وة هذا الت فى العالب إلى تعظئليه. لإمكاتية مشاركة 
الملفات عمإهط؟ الخاصة بالويندوزء لهذا عليك التأكد من تفعيلها قبل 
تفعيل الاختيار: 
Enable FILESTREAM for file [O streaming access‏ 
ولقعل هذاء اتبع الخطوات التالية: 
- افتح متصفح الويندوز 12ع101م12 Windows‏ ومن القائمة 
الرئيسية 10015 اضغط .Folder Options‏ 
- في نافذة خيارات المجلدات» اضغط الشريط العلوي ه1/آ: 
وتأكد من وضع علامة الاختيار أمام الخيار الأخير في قائمة 
الخيارات: 
Use simple file sharing.‏ 
- اضغط )0 لإغلاق النافذة. 
وإذا كنت فعلت خيارات مجرى البيانات 2۳٥5)۲ع‏ ]۴ الخاصة بخادم 
سيكويل قبل تفعيل المشاركةء فقم بتعطيل الخيارات جنوع)1116»5» 
وأعد تشغيل خادم سيكويل ۲٤۲)و‏ م ۸› ثم أعد تفيعل خيارات مجرى 
N E‏ وتيمرة دض ل أي اميك ل جلناف افيا كد 
الخاصة بسيكويل سيرفرء والتي يحفظ فيها الملفات الخارجية. 








- اضغط )0 لإغلاق النافذة وحفظ هذه التغييرات. 


۲- تفعيل استخدام مجرى البيانات ٤ES۲۸ ٤۸۷‏ ۴۳11 في خادم سيكيول: 
لفعل هذا« افتح مدير سيكويل »SQ1 Server Management Studio‏ وفي 
متصفح الكائنات Object Browser‏ حدد العنصر الرئيسي في الشجرة (الذي 
يحمل اسم خادم سيكويل ۲۸۴88 »)SQ18E>X‏ واضغطه بزر الفأرة الأيمن» 
ومن القائمة الموضعية اضغط الأمر مها سيعرض هذا نافذة 
خصائص خادم سيكيويل.. اضغط العنصر 80732060 من القائمة اليسرى» 
لعرض الخصائص المتقدمة» كما هو موضح في الصورة: 
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Full access enabled 
Disabiad 
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E] Miscellaneous 
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Bloced Provess 11010 





Cursor Threshold 
Def ak موشروعه | ]ارك‎ 
أو‎ au, جوج دوم ا‎ 
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E Parallelism 


جم Cor‏ 
ساسك مد" PCSOLXPRESS Cot Threshold for‏ 
Locus‏ 
Connector 2‏ 
0 ناولاو بوم Of‏ جوبوو0 Max‏ 0 
حونو قفكم 
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ستجد أول خاصية فيها هي 1.671 400655 ۳هءء†ءم]۴؛ التي توضح كيفية 
التعامل مع الملفات الخارجية.. ستجد قيمة هذه الخاصية 121936160 أي أن 
التعامل مع لات التخارحية ممتوع !.. اط القاقمة الشيدلة:.واختر ااال 
الكامل 1236160 ووعع46 1011.. هذا يسمح بالتعامل مع الملفات مباشرة» أو 
من خلال الاسقدلاماك. أما إذا أررفت فصر العا مع النلفاك: من خلال 
ا 8601 فطل فار الاك يسان الان 
Access Enabled‏ SQ1L-ransactا..‏ اضغط الزر )0 لإغلاق النافذة.. 
ستظهر لك رسالة تخبرك بأن بعض التغييرات لن تحدث إلا إذا أوقفت خادم 
سيكويل عن العمل وأعدت تشغيله ٤هو ..۸R‏ يمكنك فعل هذا من مدير تهيئة 
خادم سيكويل Server Configuration Manager‏ 501 كما تعلمنا من قبل. 


"- تفعيل استخدام مجرى البيانات 1711,1:511+1541/1 في قاعدة البيانات: 
يمكنك فعل هذا عند إنشاء قاعدة البيانات بجمل ,7-501 وذلك باستخدام السمة 
51 (هذا خارج نطاق هذا الكتاب).. كما يمكنك تعديل قاعدة 
الإيائناك بعد إنشاكها اقول هته الخاصية ولك بانمتهدام الواعينة المركية 
لمدير سيكويل 51010110 ..SQ1 Server Management‏ افترض أننا نتعامل 


1۹۷ 








مع قاعدة بيانات الكتب كمثال.. اتبع الخطوات التالية لتفعيل حفظ البيانات 

خارجها: 

- افتح متصفح الكائنات 1ع101م:1 ٥زط0‏ في مدير سيكويل. 

- ألحق طعه†)A‏ قاعدة البيانات 1014م.0:1800125 إن لم تكن موجودة. 

- اضغط قاعدة بيانات الكتب بزر الفأرة الأيمن» ومن القائمة الموضعية 
اضغط 61]165م210. 


UPBEAT ب‎ - BOOKS. MDF 










< caanaer له‎ 


(Cermertih 


Sarre 

ديو داك كما 
Cor nectieore‏ 
POA dirist stor‏ 


7 ‘ian conracien عجن عمدمع‎ 


5 في نافذة الخصائص» اضغط العنصر FileGroups‏ من القائمة اليسرى. 
ولو وال وا نن 
أ. النصف العلوي يعرض مجموعات الملفات العادية (ملفات قاعدة 
البيانات الأساسية).. ويمكنك إضافة مجموعة أخرى لو أردت 
تقسيم قاعدة البيانات على أكثر من ملف. 
ب. النصف السفلي يتعامل مع الملفات الخارجية ررروءع6)وه1'11.. هذا 
هو النصف الذي يعنينا.. اضغط الزر 400 لإضافة صف جديد» 
وفي خانة الاسم اكتب «FILESTREAM‏ وضع علامة الاختيار 
في الخانة 106151114 كما هو موضح في الصورة. 
- من القائمة اليسرى اضغط العنصر وع ]۴ لعرض ملفات قاعدة البيانات» 
وفي الجهة اليمنى اضغط الزر ل۸4 لإضافة صف جديد. 
- اكتب في خانة الاسم 8001511165 .. سيكون هذا هو اسم المجلد الذي 
سيتم حفظ الملفات التابعة لقاعدة البيانات فيه. 


3۹۸ 


في الخانة ممر1آ م711 أسدل قائمة العناصر واختر النوع 
5141 1. هذا سيجعل الخانة م111601011 تحتوي على القيمة 
7111511114 أيضا. 

استخدم الزر الموجود في الخانة 221 لاختيار موضع حفظ المجلد.. هناك 
شرط إجباري عليك الالتزام به» وهو حتمية اختيار مسار على جزء من 
القرص الصلب مهيأ بتنسيق 711175 ولیس 5,8132. 

اضغط 0 لتنفيذ كل ما فعلناه.. ستجد أن مجلدا اسمه 800151165 قد تم 
إنشاؤه على المسار الذي اخترته.. ويسمى هذا المجلد بحاوية الملفات 
Data Container‏ أو بمجموعة الملفات منا0رع»1511.. لاحظ ما يلي: 


أ- 


ب 


0 


د- 


لا كك انشام محم عات مات سند اخلة: 
EEN‏ لاقيف O EN E E‏ 
Compressed Volume‏ من القرص الصلب. 

لا يتم تشفير البيانات المحفوظة في الملفات الخارجيةء حتى لو 
كانت قاعدة البيانات تقوم بتشفير بياناتها.. لهذا لو كان التشفير 
مهما بالنسبة لك» فأرسل البيانات مشفرة منذ البداية إلى قاعدة 
البيانات. 

يمكنك استخدام أوامر التحديث مهلم ل والحذف عtم[م5‏ 
والإذراج Jl Insert‏ الخاصة بلغة SQL‏ للتعامل چ ا الذي 
E u‏ عادي» حيث ستقوم قاعدة البيانات TE‏ هذه التغييرات 
على الملف الخارجي دون أن تشغل ذهنك بهذا. 


ه- لا يمكنك استخدام الأمر ع17787816. 112104117 لكتابة البيانات مجزأة 


في عمود يحفظ بياناته في ملف خارجي. . وبدلا من هذا عليك 


استخدام الفئة SqIFileStream‏ التي سنتعرف عليها لاحقاء لكتابة 
أجزاء البيانات في الملف مباشرة. 


- تفعيل استخدام مجرى البيانات ۴11٤5۲۸٤۸ M‏ في العمود: 


الآن يمكنك إنشاء عمود في جدول الناشرين (على سبيل المثال) يحفظ بياناته 
في ملفات خارجية.. لكن للاسف» لا يحتوي مصمم الجدول على خاصية تتيح 
لنا القيام بهذا بطريقة مرئيةء لهذا ليس أمامنا سوى استخدام استعلام 
1-01.. لفعل هذا اتبع ما يلي: 

- في متصفح الكائنات» اضغط اسم قاعدة البيانات B0OOKS.MDF‏ بزر 
الفأرة الأيمن» ومن القائمة الموضعية اضغط الأمر 011617 سwه..‏ 

في نافذة الاستعلامات» اكتب الاستعلام التالي: 


ALTER TABLE Publishers 


ADD Logo3 VARBINARY(MAX) FILESTREAM NULL, 


58 


RowGuid UNIQUEIDENTIFIER 
NOT NULL ROWGUIDCOL 
UNIQUE DEFAULT NEWIDO 
GO 
هذا الاستعلام يضيف إلى الجدول 2101151615 عمودين جديدين:‎ 
VARBINARY (MAX) أ. العمود 03ع0[« وهو من النوع‎ 
ويقبل‎ ›۴1 1٤S۸ ٤۸M وسيحفظ بياناته في ملف خارجي‎ 
.NULL القيمة‎ 
ب. والعمود أأا۸0W6»؛ وهو معرف متفرد للجدول‎ 
«NOT NULL ولا يقبل العدم‎ 51011181101:17111"111+ 
..۸0WGU1)DCOL وهو يعمل كمعرف لصفوف الجدول‎ 
لاحظ أن وجود هذا العمود إجباري إذا أردت استخدام الملفات‎ 
الخارجيةء لأنه يستخدم في ربط الملف بالصف الذي يحفظ بياناته‎ 
.,11111 لهذا لا يمكن أن يقبل هذا العمود القيمة‎ 
ولتنفيد هذا الاستعلام» اضغط في أي موضع من النافذة بزر الفأرة الأيمن»‎ 
واضغط الأمر ما٥ م×8.. سيظهر في الجزء السفلي من النافذة رسالة‎ 
تخبرك بنجاح أو فشل التنفيذ.‎ 
و الاسترشاد بهذا الاستعلام في المواقف الممالثة» فكل ما عليك هو‎ 
تغيير اسم الجدول ١۲ع طوءنااں" واسم العمود 03ع[ ليصير الاستعلام‎ 
مناسبا لاحتياجاتك.‎ 


الآن فقط أنجزنا المهمة كاملة» وبإمكانك أن تحفظ صورة في الحقل 03ع10 
الخاص بالناشر الأول» باستعلام عادي كالتالي: 

UPDATE Publishers 

SET Logo3 = @Logo 

WHERE ID =1 

ويمكنك تنفيذ هذا الاستعلام بضغط الزر Write t0 ۴] Sram‏ في المشروع 

Large‏ حيث سيظهر لك مربع حوار اختيار صورة.. اختر أي 

صورة تريدها واضغط 0.. الآن لو فتحت المجلد 80015171165 فستجد ملفا 

جديدا قد أضيف إليه.. هذا الملف سيحمل اسما عجيبا لضمان عدم تشابه أسماء 

الملفات» لكنك لو أخذت نسخة منه وغيرت امتدادها إلى امتداد صورة 
(مآط. مثلا) فستجد أنها نفس الصورة التي اخترتها 
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ولو عرضت بيانات جدول الناشرين» فستجد في الخانة التي حفظنا فيها الصورة 
أرقاما سداسية عشرية» تشير إلى موضع ملف الصورة في المجلد وع80015171. 
ويمكنك قراءة بيانات هذه الصورة باستعلام عادي كالتالي: 

SELECT ID, Logo3 

FROM Publishers 

حيث يمكنك قراءة بيانات الصورة كاملة أو بطريقة تتابعية Sequential‏ باستخدام 
قارئ البيانات 1723162061 كما سنرى لاحقا.. وهذا هو نفس ما يمكنك فعله مع 
البيانات الثنائية المحفوقفة في قاعةة البيانات مثل من قرز أو 
(×varbinary)MAر..‏ ويمكنك ضغط الزر 111651620 1630 في المشروع 
ReadLargeData‏ لتجربة قراءة الصورة التى حفظتها خارج قاعدة البيانات» 
حيث سيتم حفظها على المحرك )0:١‏ بالاسم 0 0801.آ. 
وهكذا نكون قد تعاملنا مع الملف الخارجي كأنه جزء من قاعدة البيانات.. يتبقى إذن 
أن نعرف كيف نتعامل مع هذا الملف مباشرة.. هذا هو دور الففة 
ممطوع 111165 . فلنتعرف عليها. 











SqIFileStream Class فئة مجرى بيانات سيكويل‎ tg 


هذه الفئة ترث الفئة :ه45 مما يعني أنها تملك خصائص ووسائل القراءة من 
الملفات والكتابة فيها (راجع فصل الملفات في كتاب إطار العمل).. لكن هذه الفئة 
مخصصه ة للتعامل مع الملفات المحفوظة خارج قاعدة البيانات من خلال السمة 
.FILESTREAM‏ 
ولحدث إنشاء هذه الفئة صيعتان: 

-١‏ الصيغة الأولى تستقبل ثلاثة معاملات» هي بالترتيب: 


استعلام ر5001» باستخدام الوسيلة ( )36611220 . التي تستخدم مع 
اسم العمود الذي يحفظ بياناته في ملفات خارجية. 

مصفوفة وحدات ثنائية 41337 2316 تحتوي على محتوى التعامل 
.Transaction Context‏ ب الحصول عليها من خلال ر 
.GET FILESTREAM TRANSACTION CONTEXT‏ 

لاحظ أنك لا تستطيع إرسال القيمة عمنط]710 إلى هذا المعامل.. هذا 
معناه أن عليك التعامل مع الملف من خلال تعامل ہTransacti0..‏ 
هذا يلفت انتباهك إلى أن سيكويل سيرفر ما زال ينظم عملية الكتابة في 
الملف» وإن حدث أي خطأ فسيلغي كل التغييرات» ولن يتم حفظ هذه 
الاسر أك إلا إذا سييست يسسماهراء التعسيائلات 
۰0m mit "ransactions‏ كما سنعرف لاحقا 

إحدى قيم المرقم ووعنع 6ر581 التي توضح الطريقة التي تريد التعامل 
بها مع الملف: للقراءة ‘Read‏ للكتابة cWrite‏ أم للقراءة والكتابة معا 
.ReadWrite‏ 


؟- الصيغة الثانية تزيد على الصيغة الأولى بمعاملين إضافيين: 


معامل من نوع المرقم 1005)م1116)00» يحدد خيارات التمعامل مع 
الملف.. وقد تعرفنا على هذا المرقم في فصل الملفات في كتاب برمجة 
إطار العمل» لكن ما يهمنا من قيمه هنا هو القيمة جره 560116111215» 
فهي تتيح لنا قراءة أجزاء من الملف على التواليء والقيمة 
1149 التي تتيح لنا القراءة من أي موضع في الملف 
دون ترتيب. 

عدد صحيح يستقبل الحجم المبدئي الذي تريد حجزه للملف عند 
إنشائه.. وإذا أردت استخدام القيمة الافتراضية الخاصة بدوت نت» 
فأرسال إلى هذا المعامل القيمة صفر. 


وإضافة إلى ما ترثه من الفئة الأم من وسائل وخصائصء تمتلك هذه الفئة 
الخاصيتين التاليتين: 


3 الاسم :Name‏ 
تعيد مسار الملف المرسل إلى المعامل الأول في حدث الإنشاء. 


ونج محتوى التعامل :TransactionContext‏ 
تعيد مضو فة محتوى التعامل الفزسلة إلى المعائل الثاني في هدك الإنشاء: 


وستجد مثالا على استخدام هذه الففة في الزر S1۴15412. R44‏ في 
المشروع 5620138610218 .. في هذا الزر نستخدم الاستعلام التالي: 
و( SELECT ID, Logo3.PathName(‏ 
GET FILESTREAM TRANSACTION CONTEXT ()‏ 
From Publishers‏ 
هذا الاستعلام يعيد ثلاثة حقول؛ هي بالترتيب: رقم الناشرء مسار ملف الصورة 
مصفوفة محتوى التعامل :ع00014 1132531105 الخاصة بالملف.. ويستخدم 
الكود هذه الحقول لفتح الملف وقراءة محتوياته» وحفظها في ملف جديد على المسار 
0 
وستجد مثالا على استخدام هذه الفئة لحفظ صورة في الخانة 1.0603 الخاصة 
بالناشر الثانيء وذلك في الزر Writ‏ .eStreamا1FوS‏ في المشروع 
WriteLargeData‏ .. في هذا الزر استخدمنا استعلاما شبيها بالاستعلام السابق» 
لكننا لجأنا أولا إلى حيلة صغيرة» فقد استخدمنا استعلاما آخر لوضع القيمة 711111 
في الملف» وفصلنا الاستعلامين بالفاصلة المنقوطة: 
UPDATE Publishers‏ 
SET Logo3 = 0x0‏ 
Where ID =2;‏ 
و( SELECT Logo3.PathName(‏ 
GET FILESTREAM TRANSACTION _ CONTEXT ()‏ 
From Publishers‏ 
Where ID =2‏ 
الحكمة من وراء هذاء هو أن خانة الصورة لو كانت فارغة فلن يكون هناك ملف 
مرتبط بهاء وستعيد الوسيلة ©2210 القيمة 71111 وبالتالي لن نستطيع الكتابة 
في الملف بالفئة 72هع50117116516.. لهذا سنضع في الخانة القيمة 0×0.. هذا 
يجعلها تنشئ ملفا وتتركه فارغاء لكن ما يعنينا هنا هو أننا نستطيع معرفة مساره 


للكتابة فيه.. أما لو كان هناك ملف فعلا وبه بيانات» فسيتم محوهاء وهذا يناسبنا 
فعلاء لأننا سنكتب بيانات جديدة. 

أما لو أردت إضافة بيانات إلى نهاية ملف موجود» فستحتاج أولا إلى استخدام 
الوسيلة ع[عع220.5ع5011116511 للوصول إلى نهاية هذا الملف قبل بدء الكتابة 
فيه» بنفس الطريقة التقليدية التي تتعامل بها مع الملفات العادية: 


SqIFileStream.Seek(0, SeekOrigin.End) 
طبعا في هذه الحالة لن تستخدم الاستعلام الذي يضع القيمة 0×0 في الخانةء لأنك‎ 
تريد المحافظة على بيانات الملف الموجود.‎ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


ملحق : ۳ 
إعداد تطبيق قواعد البيانات على جهاز العميل 


العميل.. لفعل هذا اتبع الخطوات التالية: 


-١‏ قم بإعداد إطار العمل ]701:1 ۴٣۸۳۴‏ +716. على جهاز العميل: 
استخدم إصدار إطار العمل الذي أنشأت البرنامج عليه في دوت نت.. 
ستجد ملف إعداد إطار العمل على القرص الخاص بدوت نت حيث سييبدأ 
اسمه بالحروف: 10]3211:2.. أو يمكنك تحميله من موقع ميكروسوفت. 


١‏ - قم إعداد قاعدة البيانات: 
إذا كنت تتعامل مع قاعدة بيانات سيكويل سيرفرء فيجب إعداد نسخة 
مناسبة من تطبيق 56171 .501 على جهاز العميل (إن كانت قاعدة 
البيانات محلية «(Local‏ > أو إعداده على الخادم إمرإم؟ إن كانت قاعدة 
البيانات ستخدم أكثر من مستخدم» وفي هذه الحالة عليك ضبط إعدادات 
الاتصال بالخادم وال 1۲ الذي سيتيح الاتصال به من الأجهزة الأخرى 
(في الغالب هذه مسئولية مدير الشبكة).. وفي كلتا الحالتين» يجب أن تضع 
قاعدة البيانات في العنوان الذي يتوقع برنامجك أن يجدها فيه (كما حددته 
في نص الاتصال 511126 02601101 ©)» أو الأفضل من هذا أن يسمح 
برنامجك للمستخدم باختيار موضع قاعدة البيانات من على الجهاز أو 
تسمح له بكتابة عنوان الخادم 7[ في نافذة مخصصة لهذا الغرض 
وإذا كنت تستخدم نسخة SQL Server Express‏ فانظر المقطع الخاص 
به في نهاية هذا الملحق. 


۳- قم بإعداد عارض التقارير: 
إذا كان برنامجك يعرض بعض التقارير باستخدام Repo] Viewer‏ أو 
«Crystal Report‏ فعليك بإعداد المكتبات اللازمة لهذه التقارير على 
جهاز العملي.. على سبيل المثال» تحتاج التقارير التي تستخدم الأداة 
Report Viewer‏ إلى برنامج إعداد اسمه: 
Microsoft Report Viewer 2012 Runtime‏ 


وهو بدوره يحتاج لوجود إعدادات مسبقة لأنواع سيكويل سيرفر المدارة 
على جهاز المستخدم» فإن لم تكن موجودة» فيلزمها برنامج إعداد اسمه 
15 . وكلاهما يمكن تحميله من موقع ميكروسوفت. 


4 - قم بإعداد برنامجك: 

لو ف م اا ا الا يك 
على جهاز العميل بدون الحاجة لأي إعدادات أخرى.. كل ما عليك فعله 
هو وضع كل الصور والملفات اللازمة لعمل برنامجك في مجلد واحد مع 
الملف التنفيذي (مع مراعاة كتابة الكود منذ البداية ليقرأ هذه الملفات من 
نفس مجلد الملف التنفيذي)؛ ثم نسخه إلى جهاز العميل. 

ا کت عامل مع ادات خاضة سناع ر غد روطي فين فى بسكل 
الويندوز ,زوزعع1»: ففي هذه الحالة عليك إنشاء برنامج حزم وتوزيع 
Setup Package‏ يقوم بإعداد برنامجك على جهاز المستخدم.. وقد 
شرحت هذا الموضوع بالتفصيل في الفضل الأخير من مرجع "من الصفر 
إلى الاحتراف برمجة نماذج الوندوز". 


ملحوظة: 

الشرح السابق يخص تطبيقات قواعد البيانات الخاصة بشركة أو عميل محددء لأنك 
هنا تعد البرنامج مرة واحدة فقط لعميل واحدء وبالتالي تستطيع أن تريه هذه 
الخطوات عمليا وتدربه عليها ليقوم بها بنفسه بعد ذلك» مع كتابة ملف تعليمات 
يشرح له هذه الخطوات» بحيث لا يحتاج إليك بعد هذا. 

لكن الأمر سيختلف مع البرامج التي تباع في السوق لمستخدمين كثرء ففي هذه 
الحالة عليك أن تكتب برنامج إعداد يقوم بكل أو معظم الخطوات السابقة آليا (أي 
أنك ستجمع كل الخطوات في الخطوة رقم ؛ في الشرح السابق).. وفي الغالب 
سيستثنى من الأمر إعداد سيكويل سيرفر لأنه تطبيق مستقل بترخيص» كما أن 
إعداده على خادم يعمل على شبكة أمر يخص المسئولين عن إدارة هذه الشبكة 
وتأمينها وومنح الصلاحيات لمستخدميها. 


هل يمكن الاعتماد على نسخة 55 1م12 5001561761 عند توزيع البرنامج؟ 
95 5001-5156 هي النسخة المجانية من سيكويل سيرفر» وهي تسمح 
لك بالتعامل مع قاعدة بيانات يصل حجمها الأقصى إلى ٠١‏ جيجا بايت» وعمليات 
متزامنة تستهلك ١‏ جيجا من الذاكرة بحد أقصى.. ورغم أن هذه القيود تبدو فقيرة 
للغاية بجوار ما يمكن أن تفعله النسخة الكاملة من سيكويل سيرفر» تظلّ النسخة 
المجانية مناسبة جدا للتطبيقات التي تعمل على جهاز شخصي أو شبكة صغيرة أو 
موقع إنترنت صغيرء فملء قاعدة بيانات ب١٠‏ جيجا من البيانات أمر صعبء ما لم 
والملفات كبيرة الحجم. 
لكن.. ماذا لو زاد الضغط على قاعدة البيانات وامتلأت فعلا وتوقف التعامل معها 
(فلنقل بعد عامين أو ثلاثة مثلا)؟! 
أنا في الحقيقة» لست من أنصار ترك قاعدة البيانات تتضخم بلا حد حتى لو كنا 
نتعامل مع النسخة الكاملة من سيكويل سيرفر.. فزيادة حجم قاعدة البيانات يعني ما 
يلي: 
- - وقت أطول في البحث والفهرسة والتحديث والضغط والإصلاح. 
- مشاكل أكثر عند حفظ نسخ احتياطية من قاعدة البيانات» تتعلق بمساحة 
التخزين وبطء النقل. 
- وجود بيانات كثيرة قديمة قد تكون الحاجة إليها قد انتهت أو قلت» تظل 

تدخل في عمليات حسابية أو نقدية أو إحصائيات أو نتائج بحث أو غير 

ذلك. 
لهذا يوجد حل عملي بسيطهء يُستخدم حتى خارج النظم الرقمية في أي تعاملات 
ورقية حكومية أو تجارية» وهو إغلاق قاعدة البيانات في نهاية كل عام» وإنشاء 
قاعدة بيانات جديدة بتاريخ السنة التالية.. وهكذا يحتفظ البرنامج بقاعدة بيانات مغلقة 
لكل سنة مضت» ويتعامل فقط مع قاعدة بيانات السنة الحالية مع تقديم إمكانية 
للمستخدم لفتح قواعد بيانات السنوات الماضية للبحث فيها (بصلاحية مستخدم) أو 
تعديلها (بصلاحية المدير). 


نصيحة: في النظم التي يملك فيها أكثر من مستخدم صلاحية التعديل؛ احفظ في كل 
سجلء بيانات المستخدم الذي أدخله وآخر مستخدم عذله»ء لمنع أي تلاعبات. 


لو خططت برنامجك بهذه الطريقة» فستكون نسخة 12201655 Server‏ ,5001 كافية 
للأعمال الصغيرة والمتوسطة التي لا يزيد حجم البيانات الذي تحفظه سنويا عن 
٠‏ جيجا بايت. 

أما الشركات الكبيرة التي تحتاج أكثر من هذاء فلا أظن أنها ستمانع من شراء نسخة 
سيكويل سيرفر مرخصة كاملة الإمكانيات © 


ويمكنك تحميل نسخة 5وع1م1<2 Microsofi® SQL Server®‏ من موقع 
ميكروسوفت (على حسب الإصدار الذي تريده)» كما أوضحنا في بداية هذا الكتاب. 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته 
وقه من عذاب القبر وقه من عذاب النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
اللهم انصر المسلمين في كل مكان» 
واهزم أعداءنا وخلصنا من عملائهم الطغاة المجرمين 
آمين يا رب العالمين 


تم الكتاب بحمد الله 


أخي الفاضل: 
إذا كنت قد استفدت ببعض أو كل ما قرأته في هذا الكتاب» فلا تنسني من دعائك 
بالهداية والتوفيق والسداد والرزق وحسن الخاتمة. 
وادع لأبي رحمه الله بالرحمةء فقد نشرت هذا الكتاب مجانا كصدقة جارية له.. 
وإذا كنت في الحرم أو على مقربة منهء فلا تبخل بعمل عمرة سريعة له والدعاء 
له في الحرم المكي والحرم النبوي الشريفين. 


توا الكاتب: 


- بريدي الالكتروني: 
msvbnet@hotmail.com‏ 
- مدو نتي 
http://mhmdhmdy.blogspot.com‏ 
- قناتي على يوتيوب (تحتوي على إلقاء أكثر من ٠٠‏ قصيدة بصوتي): 
http://www.youtube.conm/user/mhmdhmdy‏ 
- صفحتي الأدبية على فيسبوك: 
https://www.facebook.com/Poet.Mhmd.Hmdy‏ 
- كتبي في مجال البرمجة بلغتي فيجوال بيزيك وسي شارب: 
http://mhmdhmdy.blogspot.com/2010/09/blog-post 95555.html‏ 
- صفحة فيجوال بيزيك وسي شارب على فيسبوك: 
https:/www.facebook.com/vbandcsharp‏ 


كتب مجانبة للكاتب للتنزيل: 
١‏ - كتب برمجية على موقع كتب: 


محمد ٠‏ "“حمدي,؟ ٠‏ ۲ غخilم/http://www.kutub.info/Iibrary/autho1‏ 
۲ - كتاب: "خرافة داروين» حينما تتحول الصدفة إلى علم": 
http://mhmdhmdy.blogspot.com/2013/11/blog-post 29.html‏ 
۳ - ديوان دلال الورد (شعر فصيح): 
http://www.mediafire.com/?n1qte7]9hdv1198‏ 
٤‏ ديوان فنجان وجع (شعر عامية): 
http://www.mediafire.com/download/gzivkgedtvx2e4j/Pain_Cup.pdf‏ 
ه - رواية 'حائرة في الحب: 
http://www.mediafire.com/?hd1]y6ca4ay3m9w‏ 
5 - رواية "حب في القطار (عمو)": 
http://mhmdhmdy.blogspot.com.eg/2015/11/blog-post 39.html‏ 


ال٠٠١‎ 


كتب مطبوعة للكاتب: 

.١‏ فيجيوال بيزيك وسي شارب: طريقك المختصر للانتقال من إحدى اللغتين 
إلى الأخرى. 

؟. المبرمج الصغير: تعلم البرمجة بفيجيوال بيزيك دوت نت. 

۳. من الصفر إلى الاحتراف: فيجيوال بيزيك دوت نت .5١١8‏ 

.٠١٠١ من الصفر إلى الاحتراف: سي شارب‎ .٤ 

5. من الصفر إلى الاحتراف: برمجة إطار العمل في فيجيوال بيزيك دوت نت. 

5. من الصفر إلى الاحتراف: برمجة إطار العمل في سي شارب. 

. من الصفر إلى الاحتراف: برمجة نماذج الويندوز في فيجيوال بيزيك دوت نت. 

. من الصفر إلى الاحتراف: برمجة نماذج الويندوز في سي شارب. 

. من الصفر إلى الاحتراف: برمجة قواعد البيانات في فيجيوال بيزيك دوت نت. 

.٠‏ من الصفر إلى الاحتراف: برمجة قواعد البيانات في فيجيوال سي 
تارب 

.١‏ المدخل العملي السريع إلى فيجيوال بيزيك دوت نت. 

. المدخل العملي السريع إلى سي شارب. 

۲۳. أساسيات 0۲۴ لمبرمجي فيجيوال بيزيك دوت نت. 

5. أساسيات 71781 لمبرمجي سي شارب. 


لتفاصيل أكثر عن هذه الكتب ومضمونها وأسعارها وأماكن بيعها: 
[لطغط. 9555 http://mhmdhmdy.blogspot.com/2010/09/blog-post‏ 


۷1۱ 





- برمجة قواعد البيانات ب .Entity Framework‏ 


- إنشاء تقارير Report Viewer‏ و .Crystal Reports‏ 
- برمجة مواقع الويب ب .ASP.NET MVC‏ 

- المواضيع المتقدمة في برمجة إطار العمل. 

- الوسائط المتعددة في .W۲۴‏ 


Windows Universal Applications برمجة مشاريع‎ - 


سجلوا إعجابكم بصفحتي البرمجية لمتابعة صدور هذه الكتب بإذن اللهء والاستفادة 


بالملاحظات البرمجية العملية التي أنشرها على الصفحة: 
https:/www.facebook.com/vbandcsharp‏ 


اللهم ارحم أبي واغفر له وكفر عنه سيئاته وقه من عذاب القبر وقه من عذاب 
النارء وأدخله الجنة وأعل منزلته فيها 
واحفظ والدتي وبارك في عمرها 
اللهم ارحم والدي كما ربياني صغيرا 
آمين يا رب العالمين 


V1 


